ThinkPHP的应用模式使得开发人员对核心框架进行改造较以往更为得心应手,并且可以让你的应用适应更多的环境和不同的需求。每个应用模式都有自己的模式定义文件,相对于ThinkPHP3.1版本,ThinkPHP3.2版本对应用模式的扩展更加明确和清晰,在ThinkPHP3.1版本中定义了Cli、Lite、Thin、AMF、PHPRPC、REST模式,其定义方式和ThinkPHP3.2版本的方式大同小异,如有需要可以参考修改,其中Cli模式被ThinkPHP框架内置,不用单独定义Cli模式即可正常使用,如需要更细化调整可以参考3.1版编写的Cli运行模式扩展。ThinkPHP同样提供了便捷的开发环境和正式环境的模式切换方式。让我们随着ThinkPHP的运行流程解析其应用模式扩展之谜。
一、应用模式的使用
在研究应用模式扩展之前,看看如何使用应用模式的吧。一般通过在入口文件定义常量APP_MODE为应用模式名称,但是在分析ThinkPHP框架入口文件时,了解到框架默认采用模式为普通模式(common),而且可以自动识别SAE环境,当然前提是没有定义APP_MODE常量时,当然ThinkPHP可以自动识别CLI和CGI模式,并且在CLI和CGI环境下运行ThinkPHP框架在默认模式中自动对这两种环境做了细微调整,当然也可以自己扩展这两种应用模式。
二、应用模式定义
在ThinkPHP框架当中除了ThinkPHP框架入口和框架引导类以外,基本所有其他功能都可以通过应用模式进行更改和扩展,如果我们要增加一个应用模式,只需要在ThinkPHP\Mode目录下面定义一个模式定义文件即可,我们可以通过分析common模式进行学习。该文件的代码如下:
我们看到这个普通应用模式代码之后,有点明了ThinkPHP的应用模式扩展是怎么回事了,但是还是知其然而不知其所以然,定义一个加载文件列表和配置是如何改变框架核心的呢?秘密就在ThinkPHP引导类中,让我们再回顾以下吧!
//加载模式中定义的config配置文件列表
foreach ($mode['config'] as $key=>$file){
is_numeric($key)?C(include $file):C($key,include $file);
}
// 读取当前应用模式对应的<a href="/tag/peizhiwenjian/" target="_blank" class="keywords">配置文件</a>
if('common' != APP_MODE && is_file(CONF_PATH.'config_'.APP_MODE.'.<a href="/tag/PHP/" target="_blank" class="keywords">PHP</a>'))
C(include CONF_PATH.'config_'.APP_MODE.'.<a href="/tag/PHP/" target="_blank" class="keywords">PHP</a>');
// 加载模式中alias别名列表定义
if(isset($mode['alias'])){
self::addMap(is_array($mode['alias'])?$mode['alias']:include $mode['alias']);
}
// 加载应用别名定义<a href="/tag/wenjian/" target="_blank" class="keywords">文件</a>
if(is_file(CONF_PATH.'alias.<a href="/tag/PHP/" target="_blank" class="keywords">PHP</a>'))
self::addMap(include CONF_PATH.'alias.<a href="/tag/PHP/" target="_blank" class="keywords">PHP</a>');
// 加载模式中tags行为定义
if(isset($mode['tags'])) {
Hook::import(is_array($mode['tags'])?$mode['tags']:include $mode['tags']);
}
// 加载应用行为定义
if(is_file(CONF_PATH.'tags.<a href="/tag/PHP/" target="_blank" class="keywords">PHP</a>'))
// 允许应用<a href="/tag/zengjia/" target="_blank" class="keywords">增加</a>开发模式配置定义
Hook::import(include CONF_PATH.'tags.<a href="/tag/PHP/" target="_blank" class="keywords">PHP</a>');
// 加载框架底层语言包
L(include THINK_PATH.'Lang/'.strtolower(C('DEFAULT_LANG')).'.<a href="/tag/PHP/" target="_blank" class="keywords">PHP</a>');
通过ThinkPHP::start()中的这段代码,完美无缝关联的模式定义文件的意义与实现方法。
三、定义简单的运行模式
手册中有一个模式扩展到的实例,可以拿到这里来分析一下,定义一个lite简洁运行模式,首先在ThinkPHP/Mode目录下新建一个lite.PHP文件内容定义如下:
从上面的配置当中我们发现core中的核心文件大多数都被替换了,当然这些需要被替换的程序功能需要我们自己去实现,不过建议大家直接拷贝普通模式中定义的核心文件过来修改。接下来我们来实现以下Think开发中的核心类库扩展文件App.class.PHP
在ThinkPHP/Mode目录下建立一个Lite目录并在lite目录下建立App.class.PHP文件,以下是程序文件的实现:
/**
- ThinkPHP 应用程序类 执行应用过程管理 Lite模式扩展类
- 实现ThinkPHP核心类库扩展时,尽可能仿造原有类库实现(除非对ThinkPHP框架源码特别了解)
- 因为在其他没有扩展的核心文件中可能会调用扩展的核心类文件中的某个方法,除非你打算全部扩展
*/
class App{
/** - 应用程序初始化
- @access public
- @return void
*/
static public function init() {
//具体现实
}
/**
- 执行应用程序
- @access public
- @return void
*/
static public function exec() {
//具体实现
}
/**
static public function logo(){
//具体实现
}
}
当文件所有扩展文件的实现后,可以在框架入口文件定义APP_MODE常量为lite
。另外需要注意一点,