php配置yii框架(转)
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
?
然后进行编译安装
?[Copy to clipboard]View Code BASH
?
1
?
?
?
./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的安装,所以这里再重新来一遍
?[Copy to clipboard]View Code BASH
?
1
2
3
4
?
?
?
/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版本。
解压缩后进入目录,并执行如下命令:
?[Copy to clipboard]View Code BASH
?
1
2
3
4
?
?
?
/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
?
1
2
3
?
?
[php] view plaincopy
?
? ? <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/
中文的: www.yiiframework.com/doc/guide/zh_cn/index