溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

高性能PHP框架Symfony2配置學(xué)習(xí)教程

發(fā)布時(shí)間:2021-09-28 18:00:01 來源:億速云 閱讀:163 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“高性能PHP框架Symfony2配置學(xué)習(xí)教程”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“高性能PHP框架Symfony2配置學(xué)習(xí)教程”吧!

一、下載

首先是下載Symfony2。本人以Ubuntu系統(tǒng)為例,采用.tgz的壓縮包,解壓源文件到/var/www目錄中并執(zhí)行:

tar zxvf Symfony_Standard_Vendors_2.0.###.tgz -C /var/www

上面的###是指版本號(hào),我下的時(shí)候是BETA5。

當(dāng)解壓之后,Symfony2的目錄如下:

/var/www/ <- Web根目錄 
 Symfony/ <- Symfony2解壓目錄 
  app/ <- 存放symfony的核心文件的目錄
   cache/ <- 存放緩存文件的目錄
   config/ <- 存放應(yīng)用程序全局配置的目錄
   logs/ <- 存放日志的目錄
  src/ <- 應(yīng)用程序源代碼
   ... 
  vendor/ <- 供應(yīng)商或第三方的模組和插件
   ... 
  web/ <- Web入口
   app.php <- 生產(chǎn)環(huán)境下的前端控制器
   ...

如果你需要安裝(如果你下載的是without vendor版本)或更新vendor(第三方)內(nèi)容時(shí),可以使用:

cd /var/www/Symfony
php bin/vendors install

二、配置

Symfony2的配置很簡(jiǎn)單,只需要在瀏覽器中輸入:

http://localhost/Symfony/web/config.php

然后按照提示來進(jìn)行就可以了。其中值得注意的就是app/cache和app/logs目錄的權(quán)限問題,由于我是在Ubuntu下安裝的,所以可以使用(其中firehare是我的用戶名,大家在這里可以用你的用戶名代替):

#為了保險(xiǎn)起見 
rm -rf app/cache/* 
rm -rf app/logs/* 
#設(shè)置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

如果系統(tǒng)不支持setfacl命令的話,要檢查2個(gè)地方:
  setfacl是否已經(jīng)安裝,如果沒有的話,可以通過以下命令安裝(在Ubuntu 11.10中好象已經(jīng)缺省安裝了,包為叫acl):

sudo apt-get install setfacl

  如果setfacl已經(jīng)安裝,那么請(qǐng)查看/etc/fstab文件,看看是否添加了acl選項(xiàng):

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

  然后根據(jù)頁(yè)面提示填寫數(shù)據(jù)庫(kù)名等信息,再將這些信息拷到/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的話,在你瀏覽器中輸入下列地址時(shí),你將得到一個(gè)Demo頁(yè):

http://localhost/Symfony/web/app_dev.php

三、程序示例:

1.創(chuàng)建Bundle

  首先創(chuàng)建一個(gè)Bundle:

php app/console gen:bundle "AcmeHelloBundle" src
  為了確保Acme名稱空間可以被自動(dòng)加載,請(qǐng)?jiān)谀愕腶pp/autoload.php文件添加下列語(yǔ)句:
$loader->registerNamespaces(array( 
 // ...
 //添加自定義的名稱空間 
 'Acme' => __DIR__.'/../src', 
 // ... 
)); 
  最后是將該Bundle注冊(cè)到Symfony2中,請(qǐng)?jiān)谀愕腶pp/AppKernel.php文件中添加下列語(yǔ)句:
// app/AppKernel.php 
public function registerBundles() 
{ 
 $bundles = array( 
  // ... 
  new AcmeHelloBundleAcmeHelloBundle(), 
 ); 
 
 // ... 
 
 return $bundles; 
}

2.創(chuàng)建路由

  路由可以創(chuàng)建在app/config/routing.yml中,但為了有個(gè)好的編程習(xí)慣和代碼組織,可以將它放在所建Bundle目錄中的Resources/config/routing.yml中,而在app/config/routing.yml中只保留到該路由文件的引用,如下所示:

# app/config/routing.yml 
homepage: 
 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.yml 
hello: 
 pattern: /hello/{name} 
 defaults: { _controller: AcmeHelloBundle:Hello:index, name:'pu' }

3.創(chuàng)建控制器:

  控制器的名字一定得是HelloController.php,原因很簡(jiǎn)單,因?yàn)槟懵酚梢呀?jīng)把控制器的名字給定下來了,在上面路由文件中的第4行和第7行中的控制器都是以AcmeHelloBundle:Hello開頭的,其中AcmeHelloBundle表示Bundle名,而Hello則表示控制器名,所以控制器必須是HelloController.php,Controller名綴是命名約定。而至于后面的index和say則是控制器類中的方法。下面就定義了index方法,當(dāng)然方法名為indexAction這個(gè)也是命名約定:

// src/Acme/HelloBundle/Controller/HelloController.php 
namespace AcmeHelloBundleController; 
use SymfonyComponentHttpFoundationResponse; 
class HelloController 
{ 
 public function indexAction($name) 
 { 
  return new Response('<html><body>Hello '.$name.'!</body></html>'); 
 } 
}

這樣,當(dāng)我們?cè)跒g覽器中輸入

http://localhost/hello/index/World

就會(huì)顯示Hello World!這樣的字樣。

4.創(chuàng)建模板:

  為了能夠重用布局文件中的區(qū)塊,可以使用模板來代替控制器中的HTML語(yǔ)句。首先創(chuàng)建頁(yè)面布局文件:

{# app/Resources/views/layout.html.twig #} 
<!DOCTYPE html> 
<html> 
 <head> 
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
  <title>{% block title %}Hello Application{% endblock %}</title> 
 </head> 
 <body> 
  {% block body %}{% endblock %} 
 </body> 
</html>

  注意,該文件位于app/Resources/views/目錄中,作用范圍是整個(gè)應(yīng)用程序的全局模板文件。在該文件中定義了兩個(gè)區(qū)塊:title和body。接下來就是創(chuàng)建一個(gè)專用于Hello控制器的模板,如下所示:

{# src/Acme/HelloBundle/Resources/views/Hello/index.html.twig #} 
{% extends '::layout.html.twig' %} 
{% block body %} 
 Hello {{ name }}! 
{% endblock %}

  在該文件中,它繼承了全局模板,并且定義了區(qū)塊body,這樣就覆寫了全局模板中的body區(qū)塊。如果系統(tǒng)在渲染到該模板時(shí),會(huì)將區(qū)塊body覆寫全局模板的區(qū)塊body,再進(jìn)行渲染。
  最后,將控制器中的HTML語(yǔ)句改成渲染上述模板即可:

// src/Acme/HelloBundle/Controller/HelloController.php 
namespace AcmeHelloBundleController; 
use SymfonyBundleFrameworkBundleControllerController; 
class HelloController extends Controller 
{ 
 public function indexAction($name) 
 { 
  return $this->render('AcmeHelloBundle:Hello:index.html.twig', array('name' => $name)); 
 } 
}

感謝各位的閱讀,以上就是“高性能PHP框架Symfony2配置學(xué)習(xí)教程”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)高性能PHP框架Symfony2配置學(xué)習(xí)教程這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI