thinkPHP3.2.2框架行为扩展及demo示例

本文实例讲述了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程序设计有所帮助。

(0)

相关推荐

  • thinkPHP中钩子的两种配置调用方法详解

    本文实例讲述了thinkPHP中钩子的两种配置调用方法.分享给大家供大家参考,具体如下: thinkphp的钩子行为类是一个比较难以理解的问题,网上有很多写thinkphp钩子类的文章,我也是根据网上的文章来设置thinkphp的钩子行为的,但根据这些网上的文章,我在设置的过程中,尝试了十几次都没有成功,不过,我还是没有放弃,最后还是在一边调节细节,一边试验的过程中实现了钩子行为的设置.下面是我个人的设置经验,在这里跟大家分享一下. 个人做了两种设置,都试验成功了,一个简单点,在thinkphp

  • 老生常谈ThinkPHP中的行为扩展和插件(推荐)

    原理分析 将标签与类之间的对应关系(如'app_init'=>array('Common\Behavior\InitHook')),通过Hook类中import或add方法,加载到Hook类中静态变量$tags中.当执行Hook中静态方法listen或者exec方法的时候(listen方法中调用了exec),实例化标签对应的类,调用相应的方法(如果是插件,调用传递的方法,如果是行为,调用run方法). Hook中exec方法定义如下: static public function exec($n

  • Thinkphp5行为使用方法汇总

    在应用或模块下建 behavior目录,目录内建行为类文件Test.PHP(以下以home模块为例) namespace app/home/behavior;//注意应用或模块的不同命名空间 class Test { public function run(&$params) { echo $params; } } 方法一 1.在入口文件中,增加: define('APP_HOOK',true); 2.home模块下建tags.PHP文件定义行为 return [ 'app_init'=>

  • ThinkPHP行为扩展Behavior应用实例详解

    本文以实例的形式详细介绍了ThinkPHP的行为扩展Behavior的实现方法,有助于读者更灵活的掌握ThinkPHP的开发,具体步骤如下: ThinkPHP 行为扩展 (Behavior) 流程: 最先是读取配置文件信息: $mode = include is_file(CONF_PATH.'core.php')?CONF_PATH.'core.php':MODE_PATH.APP_MODE.'.php'; 读取配置文件信息 ThinkPHP\Mode\common.php // 行为扩展定义

  • ThinkPHP应用模式扩展详解

    ThinkPHP的应用模式使得开发人员对核心框架进行改造较以往更为得心应手,并且可以让你的应用适应更多的环境和不同的需求.每个应用模式都有自己的模式定义文件,相对于ThinkPHP3.1版本,ThinkPHP3.2版本对应用模式的扩展更加明确和清晰,在ThinkPHP3.1版本中定义了Cli.Lite.Thin.AMF.PHPRPC.REST模式,其定义方式和ThinkPHP3.2版本的方式大同小异,如有需要可以参考修改,其中Cli模式被ThinkPHP框架内置,不用单独定义Cli模式即可正常使

  • thinkPHP下的widget扩展用法实例分析

    本文实例讲述了thinkPHP下的widget扩展用法.分享给大家供大家参考,具体如下: Widget扩展用于在页面根据需要输出不同的内容,Widget扩展的定义是在项目的Lib\Widget目录下面定义Widget类库,例如下面定义了一个用于显示最近的评论的Widget: 位于Lib\Widget\ShowCommentWidget.class.php Widget类库需要继承Widget类,并且必须定义render方法实现,例如: render方法必须使用return返回要输出的字符串信息,

  • Thinkphp5框架简单实现钩子(Hook)行为的方法示例

    本文实例讲述了Thinkphp5框架简单实现钩子(Hook)行为的方法.分享给大家供大家参考,具体如下: 实现在一个方法开始和结束加入两个行为:api_init.api_end 框架的搭建和模块的建立这里就省略了,请不太熟练的同学自行学习. 下面直接进入步骤: 1,先创建一个行为类  \application\api\behavior\AopTest.php <?php namespace app\api\behavior; //行为类 class AopTest{ //绑定api初始化 pub

  • thinkPHP5.0框架整体架构总览【应用,模块,MVC,驱动,行为,命名空间等】

    本文讲述了thinkPHP5.0框架整体架构.分享给大家供大家参考,具体如下: ThinkPHP5.0应用基于MVC(模型-视图-控制器)的方式来组织. MVC是一个设计模式,它强制性的使应用程序的输入.处理和输出分开.使用MVC应用程序被分成三个核心部件:模型(M).视图(V).控制器(C),它们各自处理自己的任务. 5.0的URL访问受路由决定,如果关闭路由或者没有匹配路由的情况下,则是基于: http://serverName/index.php(或者其它应用入口文件)/模块/控制器/操作

  • thinkPHP中钩子的使用方法实例分析

    本文实例讲述了thinkPHP中钩子的使用方法.分享给大家供大家参考,具体如下: 前面介绍过thinkPHP中钩子的两种配置调用方法,这里来进一步分析一下钩子的使用方法. 1 创建钩子行为: 我们自己定义的标签位可以直接放在Think\Behaviors中,也可以放在应用目录中,比如说Home模块下,新建一个Behaviors的文件夹,在文件夹内新建 标签名+Behavior.class.PHP 注:需要带Behavior的原因,见代码: static public function exec(

  • thinkPHP基于反射实现钩子的方法分析

    本文实例讲述了thinkPHP基于反射实现钩子的方法.分享给大家供大家参考,具体如下: ThinkPHP框架的控制器模块是如何实现 前控制器.后控制器,及如何执行带参数的方法? PHP系统自带的 ReflectionClass.ReflectionMethod 类,可以反射用户自定义类的中属性,方法的权限和参数等信息,通过这些信息可以准确的控制方法的执行. ReflectionClass: 主要用的方法: hasMethod(string)  是否存在某个方法 getMethod(string)

随机推荐