好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

Symfony安装教程

首先是下载Symfony2,这个简单,到 http://symfony测试数据/download下载即可。本人由于使用的是Ubuntu系统,所以下了个.tgz的,然后解压到/var/www目录中: i.tar zxvf Symfony_Standard_Vendors_2.0.###.tgz -C /var/www

上面的###是指版本号,我下的时候是BETA5。

当解压之后,Symfony2的目录如下: i./var/www/ <- Web根目录 ii. Symfony/ <- Symfony2解压目录 iii. app/ <- 存放symfony的核心文件的目录 iv. cache/ <- 存放缓存文件的目录 v. config/ <- 存放应用程序全局配置的目录 vi. logs/ <- 存放日志的目录 vii. src/ <- 应用程序源代码 viii. … ix. vendor/ <- 供应商或第三方的模组和插件 x. … xi. web/ <- Web入口 xii. app.php <- 生产环境下的前端控制器 xiii. …

如果你需要安装(如果你下载的是without vendor版本)或更新vendor(第三方)内容时,可以使用: i.cd /var/www/Symfony ii. php bin/vendors install

配置

Symfony2的配置很简单,只需要在浏览器中输入: i.http://localhost/Symfony/web/config.php

然后按照提示来进行就可以了。其中值得注意的就是app/cache和app/logs目录的权限问题,由于我是在Ubuntu下安装的,所以可以使用: i.#为了保险起见 ii.rm -rf app/cache/* iii. rm -rf app/logs/* iv.

v. #设置ACL vi. sudo setfacl -R -m u:www-data:rwx -m u:yourname:rwx app/cache app/logs vii. sudo setfacl -dR -m u:www-data:rwx -m u:yourname:rwx app/cache app/logs

如果系统不支持setfacl命令的话,要检查2个地方: i.i.setfacl是否已经安装,如果没有的话,可以通过以下命令安装(在Ubuntu 11.10中好象已经缺省安装了,包为叫acl):

i.sudo apt-get install setfacl i.i.如果setfacl已经安装,那么请查看/etc/fstab文件,看看是否添加了acl选项:

i.# /var was on /dev/sda7 during installation ii. UUID=c2cc4104-b421-479a-b21a-1108f8895110 /var ext4 defaults,acl 0 2

然后根据页面提示填写数据库名等信息,再将这些信息拷到/var/www/Symfony/app/config/parameters.ini文件中,如下所示: i.; These parameters can be imported into other config files ii. ; by enclosing the key with % (like %database_user%) iii. ; Comments start with ’;', as in php.ini iv. [parameters] v. database_driver=]pdo_mysql] vi. database_host=]localhost] vii. database_name=]symfony] viii. database_user=]symfony] ix. database_password=]symfony] x. mailer_transport=]smtp] xi. mailer_host=]localhost] xii. mailer_user=]" xiii. mailer_password=]" xiv. locale=]zh_CN] xv. secret=]29f96e9e70c2797cb77dd088d3954d3c38d9b33f]

如果全部OK的话,在你浏览器中输入下列地址时,你将得到一个Demo页: i.http://localhost/Symfony/web/app_dev.php

编程

创建Bundle

首先创建一个Bundle: i.php app/console gen:bundle ]Acme\HelloBundle] src

为了确保Acme名称空间可以被自动加载,请在你的app/autoload.php文件添加下列语句: i.$loader->registerNamespaces(array( ii. // … iii. //添加自定义的名称空间 iv. ’Acme’ => __DIR__.’/src’, v. // … vi.));

最后是将该Bundle注册到Symfony2中,请在你的app/AppKernel.php文件中添加下列语句: i. // app/AppKernel.php ii. public function registerBundles() iii. { iv. $bundles = array( v. // … vi. new Acme\HelloBundle\AcmeHelloBundle(), vii. ); viii.

ix. // … x.

xi. return $bundles; xii. }

创建路由

路由可以创建在app/config/routing.yml中,但为了有个好的编程习惯和代码组织,可以将它放在所建Bundle目录中的 Resources/config/routing.yml中,而在app/config/routing.yml中只保留到该路由文件的引用,如下所 示: i.# app/config/routing.yml ii. homepage: iii. pattern: / iv. defaults: { _controller: FrameworkBundle:Default:index } v.

vi. hello: vii. resource: ]@AcmeHelloBundle/Resources/config/routing.yml]

而真正的路由则写在src/Acme/HelloBundle/Resources/config/routing.yml路由文件中,如下所示: i.# src/Acme/HelloBundle/Resources/config/routing.yml ii. hello: iii. pattern: /hello/{name} iv. defaults: { _controller: AcmeHelloBundle:Hello:index, name:’pu’ }

创建控制器

控制器的名字一定得是HelloController.php,原因很简单,因为你路由已经把控制器的名字给定下来了,在上面路由文件中的第4行和 第7行中的控制器都是以AcmeHelloBundle:Hello开头的,其中AcmeHelloBundle表示Bundle名,而Hello则表示 控制器名,所以控制器必须是HelloController.php,Controller名缀是命名约定。而至于后面的index和say则是控制器类 中的方法。下面就定义了index方法,当然方法名为indexAction这个也是命名约定: i.// src/Acme/HelloBundle/Controller/HelloController.php ii.

iii. namespace Acme\HelloBundle\Controller; iv. use Symfony\Component\HttpFoundation\Response; v.

vi. class HelloController vii. { viii. public function indexAction($name) ix. { x. return new Response(‘<html><body>Hello ’.$name.’!</body></html>’); xi. } xii. }

这样,当我们在浏览器中输入 i.http://localhost/hello/index/World

就会显示Hello World!这样的字样。

创建模板

为了能够重用布局文件中的区块,可以使用模板来代替控制器中的HTML语句。首先创建页面布局文件: i.{# app/Resources/views/layout.html.twig #} ii. <!DOCTYPE html> iii. <html> iv. <head> v. <meta http-equiv=]Content-Type] content=]text/html; charset=utf-8″ /> vi. <title>{% block title %}Hello Application{% endblock %}</title> vii. </head> viii. <body> ix. {% block body %}{% endblock %} x. </body> xi. </html>

注意,该文件位于app/Resources/views/目录中,作用范围是整个应用程序的全局模板文件。在该文件中定义了两个区块:title和body。接下来就是创建一个专用于Hello控制器的模板,如下所示: i.{# src/Acme/HelloBundle/Resources/views/Hello/index.html.twig #} ii. {% extends ’::layout.html.twig’ %} iii.

iv. {% block body %} v. Hello {{ name }}! vi. {% endblock %}

在该文件中,它继承了全局模板,并且定义了区块body,这样就覆写了全局模板中的body区块。如果系统在渲染到该模板时,会将区块body覆写全局模板的区块body,再进行渲染。 最后,将控制器中的HTML语句改成渲染上述模板即可: i.// src/Acme/HelloBundle/Controller/HelloController.php ii. namespace Acme\HelloBundle\Controller; iii.

iv. use Symfony\Bundle\FrameworkBundle\Controller\Controller; v.

vi. class HelloController extends Controller vii. { viii. public function indexAction($name) ix. { x. return $this->render(‘AcmeHelloBundle:Hello:index.html.twig’, array(‘name’ => $name)); xi. } xii. }

打完收功!我们已经创建了一个典型的Symfony2程序。如果兄弟们有什么疑问的话可以下面的评论中直接提。  

查看更多关于Symfony安装教程的详细内容...

  阅读:52次