之前在sina博客寫過Yii的文章,來到博客園之後,沒再寫過關於Yii的文章,正好端午假期沒啥事,就結合以前的博客,Yii的官方文檔,再加上最近的Yii的收穫總結一下,寫個系列~~
Yii是一個基於元件的高效能PHP框架,用於開發大型Web應用。 Yii採用嚴格的OOP編寫,並有著完善的函式庫引用以及全面的教學。從 MVC,DAO/ActiveRecord,widgets,caching,等級式RBAC,Web服務,到主題化,I18N和L10N,Yii提供了今日Web 2.0應用開發所需的幾乎一切功能。事實上,Yii是最有效率的PHP框架之一。 Yii是一個高效能的PHP5的web應用程式開發框架。透過一個簡單的命令列工具 yiic 可以快速創建一個web應用程式的程式碼框架,開發者可以在生成的程式碼框架基礎上添加業務邏輯,以快速完成應用程式的開發。
安裝Yii
在安裝Yii之前,你必須設定好你的開發環境,例如支援PHP5.1.0以上版本的Web伺服器。 Yii已經在Windows和Linux作業系統上的 Apache Web伺服器測試通過。它也可能運行在其他平台上的支援PHP5的Web伺服器,網路上公佈了許多免費資源,你可能會獲得一個配置好PHP5的Web 伺服器環境。在這裡我們會拋開Web伺服器和PHP5的安裝。
Yii的安裝其實很簡單,實際上只需要兩個步驟:
- 從 http://www.yiiframework.com/ 下載Yii框架 解壓縮下載檔案到Web伺服器可存取的目錄下。
- 安裝完成後,建議你檢查一下目前伺服器是否已經滿足了Yii的所有要求。
幸運的是,這樣做很容易,Yii自帶了一個簡單的檢查工具。要呼叫它,在你的瀏覽器網址列輸入:http://yourhostname/path/to/yii/requirements/index.php,下面將顯示你伺服器的設定。使用檢查工具,確定伺服器沒有安裝和使用擴充功能或元件,但它只是給出一個建議,以確保可以確定安裝。如你所看到的,下在的檢查結果,並非都是 Passed(通過)狀態,也有部份顯示Warning(警告)。當然,你的配置情況可能會略有不同,因此,你的顯示結果也會有所不同。其實下面的細節部份沒有必要全部能通過。但部份也是必要的,根據 Conclusion(結論)這個段落的內容:你的伺服器配置滿足了Yii的最低要求。 (Your server configuration satisfies the minimum requirements by Yii.)
建立一個新的應用程式
- Yii的安裝位置是你已經知道的
- WebRoot是你的Web伺服器設定的根目錄
- 從你的命令列,進入到framework目錄,並執行以下內容:
- % cd Webroot/testdrive/framework
- % yiic webapp ../../testdrive
- Create a Web application under '/WebRoot/testdrive'? [Yes| No]
- Yes
- mkdir /WebRoot/testdrive
- mkdir /WebRoot/testdrive/assets
- mkdir /WebRoot/testdrive/css
- genes/ss/bg.gene .css
- generate css/main.css
-
複製程式碼 你的應用程式已經成功創建到了/WebRoot/demo下。這個webapp指令的作用是創造一個全新的Yii應用程式。它只需要指定一個參數,無論是絕對還是相對路徑都會建立應用程式。它所產生的目錄及檔案只是應用程式的一個骨架。
- testdrive/
- index.php Web 應用入口腳本檔案
- index-test.php 功能測試使用的入口腳本檔案
- assets/ 包含公開的資源檔案
- css/ 包含CSS 檔案
- images/ 包含圖片檔案
- themes/ 包含應用程式主題
- protected/ 包含受保護的應用程式檔案
- yiic yiic 命令列腳本
- yiic.bat下的yiic 命令列腳本
- yiic.php yiic 命令列PHP 腳本
- commands/ 包含自訂的'yiic' 命令
- shell/ 包含自訂的'yiic shell' 命令
- components/ 包含可重複使用的使用者元件
- Controller.php 所有控制器類別的基礎類別
- Identity.php 用來認證的'Identity' 類別
- config/ 包含設定檔
- console.php 控制台應用程式設定
- main.php Web 應用設定
- test.php 功能測試使用的設定
- controllers/ 包含控制器的類別檔案
- SiteController.php 預設控制器的類別檔案
- data/ 包含範例資料庫
- schema.mysql.sql 範例MySQL 資料庫
- schema.sqlite.sql 範例SQLite 資料庫
- testdrive.db 範例SQLite 資料庫檔案
- extensions/ 包含第三方擴充功能 messages/ 包含翻譯過的訊息
- models/ 包含模型的類別檔案
- LoginForm.php 'login' 動作的表單模型
- ContactForm.php 'contact' 動作的表單模型
- runtime/ 包含暫時產生的檔案
- tests/ 包含測試腳本
- views/ 包含控制器的視圖和佈局文件
- layouts/ 包含佈局視圖文件
- main.php 所有視圖的預設佈局
- column1.php 使用單列頁面使用的佈局
- column2.php 使用雙列的頁面使用的佈局
- site/ 包含'site' 控制器的視圖檔案
- pages/ 包含"靜態" 頁面
- about.php "about" 頁面的視圖
- contact.php 'contact' 動作的視圖
- error.php 'error' 動作的視圖(顯示外部錯誤)
- index.php 'index' 動作的視圖
- login.php 'login ' 動作的視圖
- system/ 包含系統視圖檔案
-
複製程式碼
這時不用寫一行程式碼,我們就可以在瀏覽器中存取以下 URL 來看看我們第一個 Yii 應用程式:
http://hostname/testdrive/index.php-
複製程式碼
我們會看到的,這個應用程式包含三個頁面:首頁、聯絡頁、登入頁。首頁展示一些關於應用程式和使用者登入狀態的信息,聯絡頁顯示一個聯絡表單以便使用者填寫並提交他們的諮詢,登入頁允許使用者先通過認證然後存取已授權的內容。
配置
在這個應用程式中,不管到那個頁面url中都帶有index.php,如果想把它去掉,怎麼辦。
1. 開啟apache的mod_rewrite模組,去掉LoadModule rewrite_module modules/mod_rewrite.so前的"#"符號,確保
中有"AllowOverride All"。
2. 在專案中的/protected/config/main.php中加入程式碼:
'components'=>array(- ...
- 'urlManager'=>array(
- 'urlFormat'=>'path',
- 'showScriptName'=>false,//注意false不要用引號括上
- 'rules'=>array(
- 'sites'=>'site/index',
- ),
- ),
- ...
- ),
-
複製程式碼
3.設定伺服器,Yii可以在Apache和Nginx下設定
1)Apache
在Apache伺服器下,Yii需要設定.htaccess檔。配置如下
- RewriteEngine on
-
- # prevent httpd from serving dotfiles (.htaccess, .svn, .git, etc.)
- RedirectMatch 403. 🎜># if a directory or a file exists, use it directly
- RewriteCond %{REQUEST_FILENAME} !-f
- RewriteCond %{REQUEST_FILENAME} !-f
- RewriteCond %{REQUEST_FILENAME} !-f
- RewriteCond %{REQUEST_FILENAME} ! RewriteRule . index.php
-
複製程式碼
2)Nginx
Yii可以使用Nginx和PHP的FPM SAPI。配置如下
server {- set $host_path "/www/mysite";
- access_log /www/mysite/log/access.log main;
-
- server_name mysite;
- root $host_path/htdocs;
- set $yii_bootstrap "index.php";
-
- charset utf-8;
-
- location / {
- index index. $yii_bootstrap;
- try_files $uri $uri/ /$yii_bootstrap?$args;
- }
-
- location ~ ^/(protected|framework|themes/w+/views) { }
-
- #avoid processing of calls to unexisting static files by yii
- location ~ .(js|css|png|jpg|gif|swf|ico|pdf|mov|fla|zip|mov|fla|zip| |rar)$ {
- try_files $uri =404;
- }
-
- # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
- # fastcgi_split_path_info ^(.+.php)(.*)$;
- #let yii catch the calls to unexising PHP files
- set $fsn /$yii_bootstrap; set $fsn $fastcgi_script_name;
- }
- fastcgi_pass 127.0.0.1:9000;
- #PATH_INFO and PATH_TRANSLATED can be omitted, but RFC 3875 specifies them for CGI
- fastcgi_param PATH_INFO $fastcgi_path_info
- # prevent nginx from serving dotfiles (.htaccess, .svn, .git, etc.)
- location ~ /. {
- deny all;
- access_log off;
- log_not_found off; }
-
-
- 複製程式碼
-
-
-
-
- 使用如上配置,你可以在php.ini中設定cgi.fix_pathinfo=0,這樣可以避免許多不必要的系統的stat()呼叫。
-
-
-
基本安裝與設定就到這裡~~
|