最近,出于对Symfony2的存眷,在网上闲逛时不时会寄望Symfony2的文章,尤其是中文方面的。前段时间拜读了一饼兄的《Symfony2入门》一文,以为比官网上的例子涉及面更广便做了转载。今天有暇细读,却发明一饼兄只是概略对Symfony2做了先容,假如参照该文来入门的话,却是存在很大的问题,于是便有了这一篇文章。
下载
首先是下载Symfony2,这个简朴,到 可能本站下载。本人由于利用的是Ubuntu系统,所以下了个.tgz的,然后解压到/var/www目次中:
tar zxvf Symfony_Standard_Vendors_2.0.###.tgz -C /var/www上面的###是指版本号,我下的时候是BETA5。
当解压之后,Symfony2的目次如下:
/var/www/ <- Web根目次Symfony/ <- Symfony2解压目次
app/ <- 存放symfony的焦点文件的目次
cache/ <- 存放缓存文件的目次
config/ <- 存放应用措施全局设置的目次
logs/ <- 存放日志的目次
src/ <- 应用措施源代码
...
vendor/ <- 供给商或第三方的模组和插件
...
web/ <- Web进口
app.php <- 出产情况下的前端节制器
...
假如你需要安装(假如你下载的是without vendor版本)或更新vendor(第三方)内容时,可以利用:
cd /var/www/Symfonyphp bin/vendors install
设置
Symfony2的设置很简朴,只需要在欣赏器中输入:
然后凭据提示来举办就可以了。个中值得留意的就是app/cache和app/logs目次的权限问题,由于我是在Ubuntu下安装的,所以可以利用(个中firehare是我的用户名,兄弟们在这里可以用你的用户名取代):
#为了保险起见rm -rf app/cache/*
rm -rf app/logs/*
#配置ACL
sudo setfacl -R -m u:www-data:rwx -m u:firehare:rwx app/cache app/logs
sudo setfacl -dR -m u:www-data:rwx -m u:firehare:rwx app/cache app/logs
假如系统不支持setfacl呼吁的话,要查抄2个处所:
setfacl是否已经安装,假如没有的话,可以通过以下呼吁安装(在Ubuntu 11.10中好象已经缺省安装了,包为叫acl):
sudo apt-get install setfacl假如setfacl已经安装,那么请查察/etc/fstab文件,看看是否添加了acl选项:
# /var was on /dev/sda7 during installationUUID=c2cc4104-b421-479a-b21a-1108f8895110 /var ext4 defaults,acl 0 2
然后按照页面提示填写数据库名等信息,再将这些信息拷到/var/www/Symfony/app/config/parameters.ini文件中,如下所示:
; These parameters can be imported into other config files; by enclosing the key with % (like %database_user%)
; Comments start with ';', as in php.ini
[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="29f96e9e70c2797cb77dd088d3954d3c38d9b33f"
假如全部OK的话,在你欣赏器中输入下列地点时,你将获得一个Demo页:
编程
建设Bundle
首先建设一个Bundle:
php app/console gen:bundle "Acme\HelloBundle" src为了确保Acme名称空间可以被自动加载,请在你的app/autoload.php文件添加下列语句:
$loader->registerNamespaces(array(// ...
//添加自界说的名称空间
'Acme' => __DIR__.'/../src',
// ...
));
最后是将该Bundle注册到Symfony2中,请在你的app/AppKernel.php文件中添加下列语句:
// app/AppKernel.phppublic function registerBundles()
{
$bundles = array(
// ...
new Acme\HelloBundle\AcmeHelloBundle(),
);
// ...
return $bundles;
}
建设路由
路由可以建设在app/config/routing.yml中,但为了有个好的编程习惯和代码组织,可以将它放在所建Bundle目次中的Resources/config/routing.yml中,而在app/config/routing.yml中只保存到该路由文件的引用,如下所示:
# app/config/routing.ymlhomepage:
pattern: /
defaults: { _controller: FrameworkBundle:Default:index }
hello:
resource: "@AcmeHelloBundle/Resources/config/routing.yml"
而真正的路由则写在src/Acme/HelloBundle/Resources/config/routing.yml路由文件中,如下所示:
# src/Acme/HelloBundle/Resources/config/routing.ymlhello:
pattern: /hello/{name}
defaults: { _controller: AcmeHelloBundle:Hello:index, name:'pu' }
建设节制器
节制器的名字必然得是HelloController.php,原因很简朴,因为你路由已经把节制器的名字给定下来了,在上面路由文件中的第4行和第7行中的节制器都是以AcmeHelloBundle:Hello开头的,个中AcmeHelloBundle暗示Bundle名,而Hello则暗示节制器名,所以节制器必需是HelloController.php,Controller名缀是定名约定。而至于后头的index和say则是节制器类中的要领。下面就界说了index要领,虽然要领名为indexAction这个也是定名约定:
// src/Acme/HelloBundle/Controller/HelloController.phpnamespace Acme\HelloBundle\Controller;
use Symfony\Component\HttpFoundation\Response;
class HelloController
{
public function indexAction($name)
{
return new Response('<html><body>Hello '.$name.'!</body></html>');
}
}
这样,当我们在欣赏器中输入
就会显示Hello World!这样的字样。
建设模板