中文幫助:http://www.yiiframework.com/doc/guide/1.1/zh_cn/quickstart.what-is-yii
一、下載yiiframework,當前最新版本是1.1.6
下載地址:http://yii.googlecode.com/files/yii-1.1.6.r2877.tar.gz
二、解壓縮,配置環境
將壓縮包放在appserv的www目錄下面,啓動apache和mysql,在地址欄中輸入:http://localhost/yii6/requirements/index.php,查看配置環境,PDO和GD庫需要配置一下,打開php.ini,加入:
extension=php_pdo_mysql.dll
extension=php_mysql.dll
(當然,以上兩個文件必須提前放在php的擴展文件夾中),yii框架基於php5。
最新的PCEL下載地址:
http://downloads.php.net/pierre/
三、創建第一個應用
打開cmd,切換到appserv的www目錄下,輸入:
D:\AppServ\www>yii6\framework\yiic webapp test
Create a Web application under 'D:\AppServ\www\test'? [Yes|No] yes
D:\AppServ\www>yii6\framework\yiic webapp test
Create a Web application under 'D:\AppServ\www\test'? [Yes|No] yes
mkdir D:/AppServ/www/test
mkdir D:/AppServ/www/test/assets
mkdir D:/AppServ/www/test/css
generate css/bg.gif
generate css/form.css
generate css/ie.css
...
generate themes/classic/views/.htaccess
mkdir D:/AppServ/www/test/themes/classic/views/layouts
mkdir D:/AppServ/www/test/themes/classic/views/site
mkdir D:/AppServ/www/test/themes/classic/views/system
Your application has been created successfully under D:\AppServ\www\test.
這樣第一個應用就建立好了。
(yii6這個目錄可以放在任意一個可讀的目錄中,不一定要放在appserv的www下,在生產中,一般將此目錄放在比較安全的地方,比如:d:\,創建應用的時候,就可以:D:\yii6\framework\yiic webapp webapp d:\appserv\www\test)
(如果你使用Eclipse或者NetBeans開發工具,將YII的framework作爲包含文件,這樣開發起來提示就比較多了。^_^)
四、查看應用
地址欄中輸入:http://localhost/test/
沒寫一行代碼,就可以看到程序正常運行了。跟ROR差不多。
五、文件結構說明
六、連接數據庫
YII的數據庫連接配置在主配置文件config/main.php中進行配置。
如果是sqllite數據庫,只需要指定正確的數據庫文件位置即可;
如果是mysql數據庫,或者其他數據庫(pgsql/oracle),需要註釋掉原來的配置。
如下:(mysql)
'db'=>array(
'connectionString' => 'sqlite:'.dirname(__FILE__).'/../data/testdrive.db',
),
// uncomment the following to use a MySQL database
/*
'db'=>array(
'connectionString' => 'mysql:host=localhost;dbname=testdrive',
'emulatePrepare' => true,
'username' => 'root',
'password' => '',
'charset' => 'utf8',
),
*/
將上面的代碼修改爲:
/*
'db'=>array(
'connectionString' => 'sqlite:'.dirname(__FILE__).'/../data/testdrive.db',
),
*/
// uncomment the following to use a MySQL database
'db'=>array(
'connectionString' => 'mysql:host=localhost;dbname=test', //test爲數據庫名
'emulatePrepare' => true,
'username' => 'root', //這裏是數據庫用戶名
'password' => 'livedoor2008', //這裏是你的數據庫密碼
'charset' => 'utf8',
),
七、創建表結構並配置CRUD(注意:YII使用的php的PDO來訪問數據庫的,所以在使用數據庫時,務必配置好PDO)
第一步:創建表結構
CREATE TABLE tbl_user
(
id INTEGER NOT NULL PRIMARY KEY AUTO_INCREMENT,
username VARCHAR(128) NOT NULL,
password VARCHAR(128) NOT NULL,
salt VARCHAR(128) NOT NULL,
email VARCHAR(128) NOT NULL,
profile TEXT
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
等等,其他表結構查看yii6\demos\blog\protected\data下。
第二步:配置CRUD
YII的CRUD可以自動生成,使用GII這個工具。
要使用GII,在主配置文件中,打開GII即可,並設置密碼。
// autoloading model and component classes
'import'=>array(
'application.models.*',
'application.components.*',
),
'modules'=>array(
// uncomment the following to enable the Gii tool
'gii'=>array(
'class'=>'system.gii.GiiModule',
'password'=>'livedoor2008',
// If removed, Gii defaults to localhost only. Edit carefully to taste.
'ipFilters'=>array('127.0.0.1','::1'),
),
),
保存文件後,在地址欄中輸入:
http://localhost/test/index.php?r=gii
輸入設置密碼,便可以使用GII了。
八、根據表結構生成表的模型類
第一步,使用GII生成tbl_user的模型類:
點擊生成(Generate),模型類User.php就生成了,它位於protected/modules/下。
第二步,使用GII生成對tbl_user的CRUD操作類,並加入測試數據:
這裏,GII幫我們生成了一個UserController.php控制器文件和user的多個視圖文件。
UserController.php位於protected/controllers/下,多個視圖文件位於views/user下。
九、針對表生成並實現CRUD操作
訪問user控制器:http://localhost/test/index.php?r=user
如果要操作,需要用管理員admin/admin登錄。
查看(Read)/添加(Create)/刪除(Delete)/更新(Update),隨你了。
十、MVC基礎
M -- 模型,代表了數據(表)和具體的業務邏輯;
V -- 用戶看到的內容,文本,顏色,表單等
C -- 用來管理模型和視圖的通信
這樣做的好處就是分離的程序和頁面及業務邏輯,對於局部的修改不會影響到其他的內容。
YII的工作流分析:
http://localhost/index.php?r=post/show&id=1
假設,一個用戶請求了以上的地址,YII會做如下處理:
前端控制器index.php,會創建一個web實例,並執行此實例;
1) 應用組件request會接收此請求,並交給urlManager對請求的地址進行分割,r=post/show,表示請求的是一個叫post的控制器,並執行show動作
2) Show動作對應showAction的方法,以上創建的實例會對該方法執行關聯的過濾操作(過濾器,測試基準),如果容許訪問,繼續執行;否則訪問終止;
3) showAction會找到ID=1的模型數據,並渲染一個視圖;
4) 視圖讀取數據,並顯示post模型的屬性,執行完一些小物件後,渲染內容插入佈局文件,最後顯示給用戶。
十一、前端控制器(入口腳本)
前端控制器是唯一一個能夠直接爲用戶訪問的腳本,一個是爲了安全起見,一個是爲了生成一個應用實例。
// 在生產環境中請刪除此行
defined('YII_DEBUG') or define('YII_DEBUG',true);
// 包含Yii引導文件
require_once('path/to/yii/framework/yii.php');
// 創建一個應用實例並執行
$configFile='path/to/config/file.php';
Yii::createWebApplication($configFile)->run();
十二、使用組件
1) 通常,YII的組件隨取隨用,配置好的組件,如果不在preload中,則只有通過Yii::app()->組件ID進行訪問時候,纔會被應用創建。
2) 但是,Yii的核心組件(16個),即使不被訪問,也會被創建。
十三、使用表單
十四、關於正則表達式
$str = 'dddfew4t34233fdfew we中文2323duids,';
var_dump(preg_match('/^(([\w\s,])|([^\x{00}-\x{ff}]))+$/u', $str));
\w -- 匹配字符(字母和數字)
\s -- 匹配空格 製表符和換行符
[^\x{00}-\x{ff}]))+$/u --匹配雙字節
preg_match -- 使用perl風格的正則表達式
十五、YII的MVC結構
(一)模型 -- M
l YII的模型類均繼承自CModel或者其子類;
l 模型中封裝了數據庫的表的數據或者用戶提交的數據(通常是業務邏輯的數據),這些數據通常會被模型中定義的rules規則進行驗證;
l YII模型有2種,一種是CFormModel,一般由用戶提交,並且絕大多數是臨時的放在內存中,當然也可以通過AR存到數據庫中;另外一種是Active Record 模型,AR是一種對數據庫數據面向對象方式訪問的抽象方式,它的每一個對象表示爲數據表中的每一行,一個列的值就是這個對象的一個屬性。
(二)視圖 -- V
l 將模型中的數據,配合HTML標籤渲染;
l 視圖中一般只寫一些簡單的數據邏輯,如:循環或者條件。也可以寫一些YII的小物件或者HTML助手;更多複雜的業務邏輯放在模型(對數據的操作)或者控制器(業務邏輯)中。
(三)控制器 -- C
根據用戶的請求,協調模型和視圖,並將結果發給用戶端
控制器繼承自CController或者其子類
十六、使用AR進行數據庫操作
l 建立表的模型
通過使用GII,非常容易的建立表的模型,例如:表tbl_user
http://www.formtest.com/index.php?r=gii/model
表名爲:tbl_user
模型名爲:User
點預覽->生成,這樣就OK了。
l 在模型中編寫針對此表的操作
假設,我們就在User模型中編寫這個業務,
public function updateUser(){
$userId = '1';
$model = User::model()->find('id=:id', array(':id' => $userId));
$model->username = 'liujun';
return $model->save();
}
l 在控制器中調用此操作
Public function actionUpdateUser(){
$user = new User();
$user->updateUser();
}
十七、視圖和控制器
十八、關於敏捷開發
單元測試:每個類及其方法測試
功能測試:整體的多個相關的類進行測試
單元測試實例:
class HelloWorldTest extends CTestCase {
public function testActionIndex(){
}
}
十九、安裝xDebug
Xdebug是php調試工具,開源項目,用來調試/分析和跟蹤php代碼。
打開cmd:
Php.exe -i > d:\appserv\php5\logs\phpinfo.txt
打開這個文件,粘貼到瀏覽器(地址爲:http://www.xdebug.org/find-binary.php)的輸入框中,等待系統分析後,就可以下載合適版本的xdebug,並按照安裝方法安裝了。
例如:
1 Download php_xdebug-2.1.0-5.2-vc6.dll
2 Move the downloaded file to d:\AppServ\php5\ext
3 Edit C:\WINDOWS\php.ini and add the line
zend_extension_ts = d:\AppServ\php5\ext\php_xdebug-2.1.0-5.2-vc6.dll
上面這個是系統分析我的環境給出的下載版本和安裝步驟。重啓apache,在cmd中輸入:php.exe -v
輸出:
D:\AppServ\php5>php -v
PHP 5.2.6 (cli) (built: May 2 2008 18:02:07)
Copyright (c) 1997-2008 The PHP Group
Zend Engine v2.2.0, Copyright (c) 1998-2008 Zend Technologies
with Xdebug v2.1.0, Copyright (c) 2002-2010, by Derick Rethans
說明xdebug已經安裝成功了。此時,通過phpinfo也可以看到。
二十、安裝PHPUnit(http://pear.phpunit.de/)
爲了進行YII的單元測試,需要安裝PHPUnit。
cd d:\appserv\php5
安裝pear
go-pear.bat -- 安裝pear
設置pear環境
include_path = ".;D:\xampp\xampp\php\PEAR;D:\xampp\xampp\htdocs\yii6"
REGEDIT4
[HKEY_CURRENT_USER\Environment]
"PHP_PEAR_SYSCONF_DIR"="D:\\xampp\\xampp\\php"
"PHP_PEAR_INSTALL_DIR"="D:\\xampp\\xampp\\php\\pear"
"PHP_PEAR_DOC_DIR"="D:\\xampp\\xampp\\php\\docs"
"PHP_PEAR_BIN_DIR"="D:\\xampp\\xampp\\php"
"PHP_PEAR_DATA_DIR"="D:\\xampp\\xampp\\php\\data"
"PHP_PEAR_PHP_BIN"="D:\\xampp\\xampp\\php\\php.exe"
"PHP_PEAR_TEST_DIR"="D:\\xampp\\xampp\\php\\tests"
安裝phpUnit
pear channel-discover pear.phpunit.de
pear install phpunit/PHPUnit
輸出:
Did not download optional dependencies: pear/Image_GraphViz, pear/Log, symfony/Y
AML, use --alldeps to download automatically
phpunit/PHPUnit can optionally use package "pear/Image_GraphViz" (version >= 1.2
.1)
phpunit/PHPUnit can optionally use package "pear/Log"
phpunit/PHPUnit can optionally use package "symfony/YAML" (version >= 1.0.2)
downloading PHPUnit-3.4.15.tgz ...
Starting to download PHPUnit-3.4.15.tgz (255,036 bytes)
.....................................................done: 255,036 bytes
install ok: channel://pear.phpunit.de/PHPUnit-3.4.15
二十一、PHP功能測試
YII的功能測試,跟YII的單元測試差不多,但是擴展的不是CTextCase,而是CWebTestCase。需要把新建的類放在tests/functional下。
如何需要進行功能測試 ,需要安裝 SRC(selenium-remote-control),下載安裝包,並啓動:
http://repo1.maven.org/maven2/org/seleniumhq/selenium/server/selenium-server/1.0.3/selenium-server-1.0.3-standalone.jar
啓動服務:
D:\xampp\SRC>java -jar selenium-server-1.0.3-standalone.jar
測試:
打開protected/tests/WebTestCase.php
define('TEST_BASE_URL','http://www.phpunit.com/index-test.php/');
修改紅色字體部分。
打開protected/tests/phpunit.xml
刪除這行:<browser name="Internet Explorer" browser="*iexplore" />
D:\xampp\xampp\htdocs\phpunit\protected\tests>phpunit functional\SiteTest.php
PHPUnit 3.5.13 by Sebastian Bergmann.
...
Time: 21 seconds, Memory: 6.25Mb
OK (3 tests, 10 assertions)
二十二、進行單元測試
在MessageController中添加一個方法:
public function actionRepeat($str){
return $str;
}
在protected\tests\unit:
新建一個類:MessageTest
<?php
Yii::import('application.controllers.MessageController');
class MessageTest extends CTestCase {
public function testActionRepeat(){
$str = "HelloWorld";
$message = new MessageController('MessageTest');
$result = $message->actionRepeat($str);
$this->assertEquals($str, $result);
}
}
?>
測試結果: