作者:http://blog.csdn.net/zhoufoxcn/archive/2009/11/05/4769858.aspx
说明:因为最近工作工作关系,需要开发一个在Linux下运行的Web Application,需要对现在比较流行的一些PHP框架做一个了解和评估,下面的这篇文章是笔者最近学习一个比较新的PHP Framework的一点经历和操作步骤,因为官方的手册写得比较晦涩(特别是中文的),曾经尝试遍读它那个手册再动手,读了一大半发现仍无法理解,于是 干脆先下手为强了,因而也就有了下面的文章。
介 绍
Yii 是一个基于组件、纯 OOP 的、用于开发大型 Web 应用的高性能 PHP 框架。它将 Web 编程中的可重用性发挥到极致,能够显著加速开发进程。 Yii 适合大流量的应用,如门户、 BBS 、 CMS 及 B2B 系统等,功能丰富,性能优异,不过它的中文文档还不完善,并且有些命令行的操作是针对非 Windows 用户的,不易理解,所以制作了这篇文档。
下 载地址: http://www.yiiframework.com/download/
中 文文档地址: http://www.yiiframework.com/doc/guide/zh_cn
配 置
下 面针对本人的机器相关软件环境及路径做下说明:
Apache2.2.4+PHP5.2.5+MySQL5.1.39
在 这里需要说明的是需要在设置 Windows 环境变量,在 Path 中添加 PHP 运行环境所在的目录(如本人在原有配置后加上 ”;C:/PHP” ),因为使用 Yii 时需要 PHP 的运行环境。此外,在 PHP 版本选择时建议不要选择比较高的版本,本人是从 PHP5.3.0->PHP5.2.11->PHP5.2.5 一路降下来才运行成功的,建议尽量暂时不要使用 PHP5.3.0、 PHP5.2.11,本人在使用这两个版本过程中经常遇到一个 ext 目录下的 dll 文件不能加载的情况,当然你确认自己对 PHP 的配置相当熟悉的话例外。
因 为在 Yii 中需要开启 pdo 和 pdo_mysql ,所以请确保在运行环境所使用的 php.ini 中取消了 extension=php_mysql.dll 、 extension=php_pdo.dll 、 extension=php_pdo_mysql.dll 的注释。
Apache 的网站根路径为 D:/wwwroot ,在这个根路径下创建一个名为 YiiDemo 的文件 夹,将从网上下载到的 Yii 压缩包解压之后,拷贝进 D:/wwwroot/YiiDemo 文件夹,文件结构如下:
注: 上图中 demos 、 framework 、 requirements 是 Yii 压缩包中的文件 夹,其它文件和文件夹是本人使用 Eclipse 时创建的。此外,在 D:/wwwroot/YiiDemo/framework 文件夹下有一个 yiic.bat 文件,这个文件可以帮助我们快速生成网站架构和 MVC 相关的文件。
另 外,在本实例中 MySQL 和 PHP 都是用了 utf8 编码,不建议使用 gb2312 编码,能显示的中文字符太少,并且对其它东亚语系不支持,甚至连生僻点 的繁体中文都不能显示,而 utf8 可以解决这个问题。
创 建网站初始结构
启 动 Windows 命令行程序(在开始菜单上找到“运行”,然后输入“ cmd ”并回车),可以看到如下命令行窗口:
在 命令行方式下切换到 Yii 的 framework 目录 下用以执行 yiic 命令(实际执行的是 yiic.bat ),如下:
看 到如上图所示的信息之后,就可以使用 yiic 来创建网站结构了,在本例中我们在 D:/wwwroot/YiiDemo/framework (注意 Apache 中网站根路径为 D:/wwwroot )下创建网站,网站名字为 study ,先在 D:/wwwroot/YiiDemo/framework 下手动创建 study 这个文件夹,然后使用如下命令创建网站: yiic webapp 网 站路径,如下图:
在 输入创建网站的命令之后就会看到如上图所示的提示,键入 ”y” 之后就会在 D:/wwwroot/YiiDemo/study 目录创建网站的框架结构,如下图所示:
按 照本人机器配置,现在就可以看到 Yii 框架的雏形显示了,网址是: http://localhost/YiiDemo/study/index.php 。
生成 MVC 文件
按 照默认配置还不能使用数据库,要想获取与数据库的练习,需要更改配置,打开 D:/wwwroot/YiiDemo/study/protected/config 文件夹下的 main.php 文件,更改 components 中的配置即可, ’db’ 这一参数被注释掉了,将 ’db’ 参数设置如下:
'db'=>array(
'connectionString'=>'mysql:host=localhost;dbname=study',
'username'=>'root',
'password'=>'jeri',
),
保 存之后即可连接 MySQL 数据库了,实际使用时要根据自己的实际情况配置。
在 此将继续使用 yiic 这个命令行工具,通过 cd 切换工作路径到 D:/wwwroot/YiiDemo/study 这个文件夹,然后在命令行中可以创建 model 和 view 文件。如下:
需 要注意的是,如上图所示,因为 yiic.bat 文件在 D:/wwwroot/YiiDemo/framework 文件夹下,而当前命令行的工作路径是 D:/wwwroot/YiiDemo/study ,所以在运行 yiic 时建议使用全路径。
使 用 yiic shell 命令就可以进入 shell 命令行,在命令行看到的输入提示变为“ >> ”,键 入 model 表名就会创建对应表的 model 文件,上图下面就是使用“ model user ”成功之后就可以看到上图对应的情 况。
还 可以使用 crud (crud 分别是 create/read/update/delete 的缩写,表示常用的增删改查数据库操作 ) 表名创建对应的 coltroller 和 view 文件,如下图 所示:
比 如针对表 user 、 userlist 等使用 model 和 crud 命令之后,我们就可以在浏览器中查看这些文件了,如查看 userlist 表中的数据,可以在浏览器中输入 http://localhost/YiiDemo/study/index.php?r=userlist , 看到如下所示的图:
可 以看到尽管 MySQL 和 PHP 都是用了 utf8 编码,但是数据库中的 RealName 字段因为是中文数据导致不能正常显示,出现这种情况是因为采用了默认的 字符集连接 MySQL ,在 PHP 中直接连接 MySQL 时,如果使用了 utf8 编码,我们会在 PHP 代码中做如下设置: mysql_query("set names 'utf8'"); 但是在 Yii 中没有提供这样的机会,
我们可以在设置数据库连接字符串时指定连接数据库所使用的字符集,如 下:
'db'=>array(
'connectionString'=>'mysql:host=localhost;dbname=study',
'username'=>'root',
'password'=>'jeri',
'charset'=>'utf8',//use charset as utf8
),
这样就能正常显示了。当然也可以更改全局配置,那就是更改 D:/wwwroot/YiiDemo/framework/db 文件夹下的 CDbConnection.php 文件中的
public $charset;
改为 public $charset='utf8'; 也能正常显示了,如下图所示:
好了,至此没有写一行代码,但是已经完成了一个网站的大体框架,并且能初步实现增删改查功能了。虽然采用更改全部配置的方式也可以实现显示数据库中 的中文,但是不建议采用这种方式。在此非常感谢kingheaven的提示。