Home > Backend Development > PHP Tutorial > php配备yii框架(转)

php配备yii框架(转)

WBOY
Release: 2016-06-13 12:40:03
Original
1095 people have browsed it

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

?

? ? require_once(dirname(__FILE__).'/../../framework/yii.php'); ?

? ? #修改成: ?

? ? require_once('yii.php'); ?

?

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

则代表你配置成功了。

?

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

请看这里:

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

中文的: www.yiiframework.com/doc/guide/zh_cn/index

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template