yii具有很多当今web2.0开发所需要的特性。下边是一个简短列表。

 

MVC设计模式 :yii在WEB设计中采用经过验证的技术,可以较好的把显示与逻辑分离。

DAO,活动记录:yii充许在对象方面建立数据库模型,保存长而重复语句。

整合jquery:最流行的javascript框架之一,苦于jquery可以定屈非常高效并且多功能的javascript接口

表单输入验证:yii可以很简单啊安全的采集表单输入。具有一整套验证方法确保输入数据的正确,还有辅助的方法与组件,在验证失败时,提示错误信息。

WEB2.0组件:jquery提供的一套web2.0组件,可以自动完成输入域,树形视图等等。

验证与授权:yii内置验证。通过分级的基本角色访问控制提供授权。

主题:可以立即更改yii应用的主题。

WEB服务:yii支持自动复杂的WSDL服务说明的产生和服务请求处理的管理.

国际化和本地化:yii支持信息翻译,日期时间格式化,数字格式化和界面本地化。

分层缓存计划:yii支持数据缓存,页面缓存,片断缓存和动态内容。且缓存的存储介质可以在不改变应用代码下被更改。

错误处理和日志:错误被处理并且很人性化的显示,日志信息可以实现分类,过滤,并可以路由到不同的目的地。

安全:yii提供许多安全措施保证WEB应用阻止网络攻击。包括:防止跨站脚本,防止伪跨站点请求,防止窜改cookie等等。

遵守xhtml:由yiit组件和命令行工具生成的代码遵守xhtml标准。

自动代码生成:yii提供自动生成所需代码的工具,比如:应用框架,CRUD应用等。

完全的面向对象:yii框架遵守严格的面向对象的程序设计模式。不定义任何全局函数或变量。所定义的类层次结构给予最在程度的可用性和可定制性。

支持第三方代码:yii可以很好的支持第三方代码。例如,可以在YII应用中使用PERA或者zend framework。

详细的文档:每一个方法或者属性都有明确的说明。提供综合指导与其他方面的指导。

扩展库:yii提供由使用者撰写的组件构成的扩展库。

 

项目主页是: www.yiiframework.com/


其实安装yii就和安装ZendFramework没什么区别,要么在每个项目中包含yii,要么在服务器用php的include_path来包含。

 

解压缩下载下来的文件夹后,里面有三个子文件夹:demos(演示),framework(框架核心代码),requirements(这个里边儿是检测你的服务器配置是否支持yii框架,主要是php扩展方面)

 

接下来就先进行测试吧,把里面的requirements目录单独复制到你的web目录下,然后运行 xxx.xxx.com/requirements,这样会显示类似如下图所示,

 

image

php_yii_requirements_1

 

PDO MySQL扩展模块 未通过 所有和数据库相关的类 如果使用MySQL数据库,这是必须的。

PDO PostgreSQL扩展模块 未通过 所有和数据库相关的类 如果使用PostgreSQL数据库,这是必须的。

APC扩展模块 未通过 CApcCache

SOAP扩展模块 未通过 CWebService, CWebServiceAction

 

我的服务器目前有着四项没有通过,出去PDO PostgreSQL这项我不需要,打算把其他三项给加上。

 

PDO MySQL的扩展需要在编译php的时候增加 --with-pdo-mysql=/usr/local/mysql

SOAP需要增加 --enable-soap 和 --with-libxml-dir=/usr/local/libxml2

 

然后进行编译安装


 


./configure --prefix=/usr/local/php-5.2.9/ --enable-force-cgi-redirect 
--enable-mbstring=all --enable-mbregex --enable-mbstr-enc-trans 
--enable-versioning --enable-trans-sid --enable-ftp --with-mysql=/usr/local/mysql/ 
--with-apxs2=/usr/local/apache2/bin/apxs 
--with-soap=yes --with-curl=/usr/local/curl/ --with-zlib-dir=/usr/local/zlib/
--with-mcrypt=/usr/local/libmcrypt/ --with-gd=/usr/local/gd2 --with-jpeg-dir=/usr 
--with-freetype-dir=/usr/local/freetype --with-ttf --with-png-dir=/usr
--with-mhash=/usr/local/mhash/ --with-dom=/usr/local/libxml2 --with-iconv=/usr/local/libiconv
--with-openssl=/usr/local/openssl --with-pdo-mysql=/usr/local/mysql --enable-soap 
--with-libxml-dir=/usr/local/libxml2 && make && make install

 

由于之前进行过memcached的安装,所以这里再重新来一遍


 

 

/usr/local/php/bin/phpize
./configure --prefix=/usr/local/memcached_phpclient3.0.4 --enable-memcache --with-php-config=/usr/local/php/bin/php-config --with-zlib-dir=/usr/local/zlib/
make
make install

 

安装完成后显示:

Installing shared extensions: /usr/local/php-5.2.9//lib/php/extensions/no-debug-non-zts-20060613/

 

下来修改php.ini

首先找到extension_dir,默认的应该是:extension_dir = "./"

现在修改成:extension_dir = "/usr/local/php//lib/php//extensions/no-debug-non-zts-20060613/"

然后再找到Dynamic Extensions,在下面加上:

extension=memcache.so

 

APC扩展模块儿比较麻烦:

它的下载地址是:http://pecl.php.net/package/apc

可以从下面的列表儿选择你需要的来下载。我下载的是3.0.19 stable版本。

解压缩后进入目录,并执行如下命令:


/usr/local/php/bin/phpize
./configure --enable-apc --enable-apc-mmap --with-php-config=/usr/local/php/bin/php-config
make
make install

 

然后再次修改php.ini文件,

加入:

extension=apc.so

apc.enabled = 1

apc.cache_by_default = on

apc.shm_segments = 1

apc.shm_size = 32

apc.ttl = 600

apc.user_ttl = 600

apc.num_files_hint = 0

apc.write_lock = On

 

apc配置的一些说明:

apc.cache_by_default = On

是否默认对所有文件启用缓冲。 若设为Off并与以加号开头的apc.filters指令一起用,则文件仅在匹配过滤器时才被缓存

 

apc.enabled = On

是否启用APC,如果APC被静态编译进PHP又想禁用它,这是唯一的办法。

 

pc.filters =

一个以逗号分隔的POSIX扩展正则表达式列表。

如果源文件名与任意一个模式匹配,则该文件不被缓存。

注意,用来匹配的文件名是传递给include/require的文件名,而不是绝对路径。

如果正则表达式的第一个字符是"+"则意味着任何匹配表达式的文件会被缓存,如果第一个字符是"-"则任何匹配项都不会被缓存。"-"是默认值,可以省略掉。

 

apc.ttl = 0

缓存条目在缓冲区中允许逗留的秒数。0 表示永不超时。建议值为7200~36000。设为 0 意味着缓冲区有可能被旧的缓存条目填满,从而导致无法缓存新条目。

 

apc.user_ttl = 0

类似于apc.ttl,只是针对每个用户而言,建议值为7200~36000。

 

apc.gc_ttl = 3600

缓存条目在垃圾回收表中能够存在的秒数

此值提供了一个安全措施,即使一个服务器进程在执行缓存的源文件时崩溃, 中.国.站长站

而且该源文件已经被修改,为旧版本分配的内存也不会被回收,直到达到此TTL值为止。设为零将禁用此特性。

 

pc.max_file_size = 1M

禁止大于此尺寸的文件被缓存。

 

apc.num_files_hint = 1000

Web服务器上可能被包含或被请求的不同源文件的大致数量(建议值为1024~4096)。

如果你不能确定,则设为 0 ;此设定主要用于拥有数千个源文件的站点。

 

apc.shm_segments = 1

为编译器缓冲区分配的共享内存块数量(建议值为1)。

如果APC耗尽了共享内存,并且已将apc.shm_size指令设为系统允许的最大值,你可以尝试增大此值。

 

apc.shm_size = 30

每个共享内存块的大小(以MB为单位,建议值为128~256)。

有些系统(包括大多数BSD变种)默认的共享内存块大小非常少。

 

apc.write_lock = On

是否启用写入锁。

 

重启apache服务器

然后在phpinfo中你就会看到apc的设置了。

 

至此,需要的yii的扩展已经配置完毕了,再刷新一下儿刚才的测试网页,就变成了:

 

image

php_yii_requirements_2

 

--------------------------------------------

好了,环境测试通过了,下面接着来测试demo吧。

 

把yii的demos目录和framework目录copy到你的web目录下,并且访问: xxx.xxx.com/demos/helloworld

 

在我这里会显示:

Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 137963997 bytes) in Unknown on line 0

不知道为什么,但是后来我在php.ini中将上面的apc设置都给注释掉,再重启apache2 就没问题了,会正确的显示出:

Hello World

那就先不用apc扩展吧。

 

现将你的yii的framework目录放到合适的位置,然后修改你的php.ini的include_path,重启apache server

这个时候修改你的helloworld/index.php

?[Copy to clipboard]View Code PHP


 

<span style="color: #b1b100;">require_once</span><span style="color: #009900;">(</span><a href="http://www.php.net/dirname"><span style="color: #990000;">dirname</span></a><span style="color: #009900;">(</span><span style="font-weight: bold; color: #000000;">__FILE__</span><span style="color: #009900;">)</span><span style="color: #339933;">.</span><span style="color: #0000ff;">'/../../framework/yii.php'</span><span style="color: #009900;">)</span><span style="color: #339933;">;</span>  
    <span style="color: #666666; font-style: italic;">#修改成:</span>  
    <span style="color: #b1b100;">require_once</span><span style="color: #009900;">(</span><span style="color: #0000ff;">'yii.php'</span><span style="color: #009900;">)</span><span style="color: #339933;">;</span>

 

这个时候儿如果还是可以正确的显示出:Hello World

则代表你配置成功了。

 

好了,配置好了,如何初步的运用yii来写程序。

请看这里:

英文的: www.yiiframework.com/doc/guide/