最近出于对Symfony的关注在网上闲逛时不时会留意Symfony的文章尤其是中文方面的前段时间拜读了一饼兄的《Symfony入门》一文觉得比官网上的例子涉及面更广便做了转载今日有暇细读却发现一饼兄只是大体对Symfony做了介绍如果参照该文来入门的话却是存在很大的问题于是便有了这一篇文章
下载
首先是下载Symfony这个简单到或者本站下载本人由于使用的是Ubuntu系统所以下了个tgz的然后解压到/var/www目录中
tar zxvf Symfony_Standard_Vendors_###tgz C /var/www
上面的###是指版本号我下的时候是BETA
当解压之后Symfony的目录如下
/var/www/ < Web根目录 Symfony/ < Symfony解压目录 app/ < 存放symfony的核心文件的目录 cache/ < 存放缓存文件的目录 config/ < 存放应用程序全局配置的目录 logs/ < 存放日志的目录 src/ < 应用程序源代码 vendor/ < 供应商或第三方的模组和插件 web/ < Web入口 appphp < 生产环境下的前端控制器
如果你需要安装(如果你下载的是without vendor版本)或更新vendor(第三方)内容时可以使用
cd /var/www/Symfonyphp bin/vendors install
配置
Symfony的配置很简单只需要在浏览器中输入
http://localhost/Symfony/web/configphp
然后按照提示来进行就可以了其中值得注意的就是app/cache和app/logs目录的权限问题由于我是在Ubuntu下安装的所以可以使用(其中firehare是我的用户名兄弟们在这里可以用你的用户名代替)
#为了保险起见 rm rf app/cache/* rm rf app/logs/* #设置ACL sudo setfacl R m u:wwwdata:rwx m u:firehare:rwx app/cache app/logs sudo setfacl dR m u:wwwdata:rwx m u:firehare:rwx app/cache app/logs
如果系统不支持setfacl命令的话要检查个地方
setfacl是否已经安装如果没有的话可以通过以下命令安装(在Ubuntu 中好象已经缺省安装了包为叫acl)
sudo aptget install setfacl
如果setfacl已经安装那么请查看/etc/fstab文件看看是否添加了acl选项
# /var was on /dev/sda during installation UUID=cccbabaf /var ext defaultsacl
然后根据页面提示填写数据库名等信息再将这些信息拷到/var/www/Symfony/app/config/parametersini文件中如下所示
; These parameters can be imported into other config files ; by enclosing the key with % (like %database_user%) ; Comments start with ; as in phpini [parameters] database_driver="pdo_mysql" database_host="localhost" database_name="symfony" database_user="symfony" database_password="symfony" mailer_transport="smtp" mailer_host="localhost" mailer_user="" mailer_password="" locale="zh_CN" secret="feeccbddddcdbf"
如果全部OK的话在你浏览器中输入下列地址时你将得到一个Demo页
http://localhost/Symfony/web/app_devphp
编程
创建Bundle
首先创建一个Bundle
php app/console gen:bundle "AcmeHelloBundle" src
为了确保Acme名称空间可以被自动加载请在你的app/autoloadphp文件添加下列语句
$loader>registerNamespaces(array( // //添加自定义的名称空间 Acme => __DIR__//src // ));
最后是将该Bundle注册到Symfony中请在你的app/AppKernelphp文件中添加下列语句
// app/AppKernelphp public function registerBundles() { $bundles = array( // new AcmeHelloBundleAcmeHelloBundle() ); // return $bundles; }
创建路由
路由可以创建在app/config/routingyml中但为了有个好的编程习惯和代码组织可以将它放在所建Bundle目录中的Resources/config/routingyml中而在app/config/routingyml中只保留到该路由文件的引用如下所示
# app/config/routingyml homepage: pattern: / defaults: { _controller: FrameworkBundle:Default:index } hello: resource: "@AcmeHelloBundle/Resources/config/routingyml"
而真正的路由则写在src/Acme/HelloBundle/Resources/config/routingyml路由文件中如下所示
# src/Acme/HelloBundle/Resources/config/routingyml hello: pattern: /hello/{name} defaults: { _controller: AcmeHelloBundle:Hello:index name:pu }
创建控制器
控制器的名字一定得是HelloControllerphp原因很简单因为你路由已经把控制器的名字给定下来了在上面路由文件中的第行和第行中的控制器都是以AcmeHelloBundle:Hello开头的其中AcmeHelloBundle表示Bundle名而Hello则表示控制器名所以控制器必须是HelloControllerphpController名缀是命名约定而至于后面的index和say则是控制器类中的方法下面就定义了index方法当然方法名为indexAction这个也是命名约定
// src/Acme/HelloBundle/Controller/HelloControllerphp namespace AcmeHelloBundleController; use SymfonyComponentHttpFoundationResponse; class HelloController { public function indexAction($name) { return new Response(<html><body>Hello $name!</body></html>); } }
这样当我们在浏览器中输入
http://localhost/hello/index/World
就会显示Hello World!这样的字样
创建模板
为了能够重用布局文件中的区块可以使用模板来代替控制器中的HTML语句首先创建页面布局文件
{# app/Resources/views/layouthtmltwig #} <!DOCTYPE html> <html> <head> <meta httpequiv="ContentType" content="text/html; charset=utf" /> <title>{% block title %}Hello Application{% endblock %}</title> </head> <body> {% block body %}{% endblock %} </body> </html>
注意该文件位于app/Resources/views/目录中作用范围是整个应用程序的全局模板文件在该文件中定义了两个区块title和body接下来就是创建一个专用于Hello控制器的模板如下所示
{# src/Acme/HelloBundle/Resources/views/Hello/indexhtmltwig #} {% extends ::layouthtmltwig %} {% block body %} Hello {{ name }}! {% endblock %}
在该文件中它继承了全局模板并且定义了区块body这样就覆写了全局模板中的body区块如果系统在渲染到该模板时会将区块body覆写全局模板的区块body再进行渲染
最后将控制器中的HTML语句改成渲染上述模板即可
// src/Acme/HelloBundle/Controller/HelloControllerphp namespace AcmeHelloBundleController; use SymfonyBundleFrameworkBundleControllerController; class HelloController extends Controller { public function indexAction($name) { return $this>render(AcmeHelloBundle:Hello:indexhtmltwig array(name => $name)); } }
打完收功!我们已经创建了一个典型的Symfony程序如果兄弟们有什么疑问的话可以下面的评论中直接提
本文出自 “野火兔的窝” 博客请务必保留此出处