本文实例讲述了thinkPHP3.2.2框架行为扩展。分享给大家供大家参考,具体如下:
首先介绍一下行为扩展类,本人愚钝,还是借用tp手册上的来说:
行为(Behavior)是一个比较抽象的概念,你可以想象成在应用执行过程中的一个动作或者处理,在框架的执行流程中,各个位置都可以有行为产生,例如路由检测是一个行为,静态缓存是一个行为,用户权限检测也是行为,大到业务逻辑,小到浏览器检测、多语言检测等等都可以当做是一个行为,甚至说你希望给你的网站用户的第一次访问弹出Hello,world!这些都可以看成是一种行为,行为的存在让你无需改动框架和应用,而在外围通过扩展或者配置来改变或者增加一些功能。
而不同的行为之间也具有位置共同性,比如,有些行为的作用位置都是在应用执行前,有些行为都是在模板输出之后,我们把这些行为发生作用的位置称之为标签(位),当应用程序运行到这个标签的时候,就会被拦截下来,统一执行相关的行为,类似于AOP编程中的“切面”的概念,给某一个切面绑定相关行为就成了一种类AOP编程的思想。
那下面就入正题,讲解一下行为(Behavior)的实例
让行为工作有两种方式:
1.通过在conf目录下的tags.php文件 配置行为 通过\Think\Hook::listen(name);触发行为
2.通过\Think\Hook::add(name,class_namespace) 注册一个行为,然后触发(注册函数必须在触发函数之前)
在我们讲解实例之前,很有必要先讲讲行为是怎么触发的。
行为触发靠的是\Think\Hook::listen(name)方法,那方法里面到底做了什么,我们先看看源码:
/** * 监听标签的插件 * @param string $tag 标签名称 * @param mixed $params 传入参数 * @return void */ /** * add by yangligao 2014/8/25 * listen 个人觉得方法名称取得不怎么好理解,看程序中就知道这个方法实际上就是看$tags中有没有参数中的tag * 如果有,就触发之; * 如果没有,你懂的,过之(至少程序中是没有做操作)。 */ static public function listen($tag, &$params=NULL) { if(isset(self::$tags[$tag])) { if(APP_DEBUG) { G($tag.'Start'); trace('[ '.$tag.' ] --START--','','INFO'); } foreach (self::$tags[$tag] as $name) { APP_DEBUG && G($name.'_start'); $result = self::exec($name, $tag,$params); if(APP_DEBUG){ G($name.'_end'); trace('Run '.$name.' [ RunTime:'.G($name.'_start',$name.'_end',6).'s ]','','INFO'); } if(false === $result) { // 如果返回false 则中断插件执行 return ; } } if(APP_DEBUG) { // 记录行为的执行日志 trace('[ '.$tag.' ] --END-- [ RunTime:'.G($tag.'Start',$tag.'End',6).'s ]','','INFO'); } } // return; //thinkphp原始的样式 return $result;//笔者^_^自己添加的 }
这个方法里面记录行为的一些运行状态的值,函数最后一点笔者做了一点修改,只是让这个方法有了一份返回值(而非返回空)
最重要的地方就是
$result = self::exec($name, $tag,$params);
这个地方就开始执行所谓的行为了,先看看exec方法的源码
/** * 执行某个插件 * @param string $name 插件名称 * @param string $tag 方法名(标签名) * @param Mixed $params 传入的参数 * @return void */ /** * add by yangligao 2014/8/25 * exec 执行文件 */ static public function exec($name, $tag,&$params=NULL) { if('Behavior' == substr($name,-8) ){ // 行为扩展必须用run入口方法 $tag = 'run'; } // file_put_contents('D:/1.txt',$name,FILE_APPEND ); $addon = new $name(); return $addon->$tag($params); }
这个方法所做的就是先判断行为配置中的设定的类名中是否有Behavior这个字符串,如果有就执行一个叫run的方法
准备工作差不多了。下面动手试试实例
方法一:通过在conf目录下的tags.php文件 配置行为 通过\Think\Hook::listen(name);触发行为
我们先在Home/Conf下面准备tags.php配置文件
<?php return array( 'app_app' => array('Home\Behavior\DemoShowHelloWorldBehavior'), );
根据这个配置文件,我们还得在Home/Behavior下面准备DemoShowHelloWorldBehavior的类文件
<?php namespace Home\Behavior; use Think\Controller; /** * 这个文件的类可以继承Controller类 这样就可以使用assign方法 * 这个方法框架里面:对你的返回值不理睬,只是用作判断插件有没有出错 * 出于某个目的,笔者对Hook::listen方法作了小修改 让他可以返回值,或许会有点用 */ class DemoShowHelloWorldBehavior extends Controller{ public function run(){ $return_string = '(Home\Behavior)<font>DemoShowHelloWoldBehavior</font> is Running....^_^!<hr>'; $this->assign('behavior_assign','This is assigned by <font>DemoShowHelloWoldBehavior</font>'); return $return_string; } }
这个类文件,我们是继承的控制器,里面做了两件事:
1.返回一个字符串
2.使用Controller方法的assign方法给模板赋值
然后我们来触发这个行为,你只需要在控制器总写上一下代码以及在对应模板中输出对应变量
$behaviorReturn = \Think\Hook::listen('app_app');
<div>{$behavior_assign}</div>
这样页面就会输出行为类中assign的变量值了,行为类的返回值这里没有打印,你有兴趣可以打印看看哦
方法二:.通过\Think\Hook::add(name,class_namespace) 注册一个行为,然后触发(注册函数必须在触发函数之前)
这个与方法一唯一的区别就是他不用定义tags.php文件,取而代之的是一个php语句(如下):
\Think\Hook::add('app_app', 'Home\\Behavior\\DemoShowHelloWorldBehavior');
其他的操作都相同。
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
第十三章介绍了如何开发一个Web框架,通过介绍MVC、路由、日志处理、配置处理完成了一个基本的框架系统,但是一个好的框架需要一些方便的辅助工具来快速的开发Web,那么我们这一章将就如何提供一些快速开发Web的工具进行介绍,第一小节介绍如何处理静态文件,如何利用现有的twitter开源的bootstrap进行快速的开发美观的站点,第二小节介绍如何利用前面介绍的session来进行用户登录处理,第三小
本文向大家介绍ThinkPHP框架设计及扩展详解,包括了ThinkPHP框架设计及扩展详解的使用技巧和注意事项,需要的朋友参考一下 ThinkPHP框架是国内知名度很高应用很广泛的php框架,我们从一些简单的开发示例中来深入了解一下这个框架给我们带来的开发便捷性,以及游刃有余的扩展设计。同时也从源码分析的角度看看框架的一些不足,尽量做全面客观的评价。这里假设大家已经使用过ThinkPHP框架,基本
架构及扩展 一、单入口应用程序 基于SpeedPHP框架开发的应用程序,均是“单入口应用程序”(以下简称单入口程序),这是SpeedPHP框架的默认配置。 单入口程序概述 指在同一个应用程序中,访问者仅可以通过相同的一个文件来使用整个应用程序的功能。这个文件称作“入口文件”,而这种结构的应用程序整体就称作“单入口应用程序”。 在sp框架内,入口文件就是程序顶级目录的index.php文件。 一般而
本文向大家介绍thinkphp5框架扩展redis类方法示例,包括了thinkphp5框架扩展redis类方法示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了thinkphp5框架扩展redis类方法。分享给大家供大家参考,具体如下: 笔者在开发时发现,thinkphp5的自带redis类方法,只有简单的读取缓存、写入缓存的基本方法,远不能满足我们业务的需求。redis本身支持五种数据
本文向大家介绍thinkphp框架类库扩展操作示例,包括了thinkphp框架类库扩展操作示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了thinkphp框架类库扩展操作。分享给大家供大家参考,具体如下: 官方文档 http://document.thinkphp.cn/manual_3_2.html#lib_extend 自定义命名空间 在项目的application->common
本文向大家介绍Thinkphp 框架扩展之驱动扩展实例分析,包括了Thinkphp 框架扩展之驱动扩展实例分析的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Thinkphp 框架扩展之驱动扩展。分享给大家供大家参考,具体如下: 每个类库都可以设计自己的驱动,因此3.2版本的驱动目录没有独立出来,而是放到各个类库的命名空间下面,例如:Think\Log类的驱动放到 Think\Log\Dr
Swoole扩展 到GitHub首页下载Swoole扩展源码,地址:https://github.com/swoole/swoole-src 下载后按照标准的PHP扩展编译方式进行编译和安装。一般是 phpize ./configure make install 编译安装完后,修改php.ini加入extension=swoole.so开启swoole扩展。也可以通过dl('swoole.so'
CodeIgniter 的钩子特性提供了一种方法来修改框架的内部运作流程,而无需修改 核心文件。CodeIgniter 的运行遵循着一个特定的流程,你可以参考这个页面的 应用程序流程图 。但是,有些时候你可能希望在 执行流程中的某些阶段添加一些动作,例如在控制器加载之前或之后执行一段脚本, 或者在其他的某些位置触发你的脚本。 启用钩子 钩子特性可以在 application/config/conf