技术文章
当前位置:首页 > PHP编程文章 > ThinkPHP中的行为扩展和插件

ThinkPHP中的行为扩展和插件总结

  • 发布时间:
  • 作者:码农之家原创
  • 点击:218

这篇文章主要知识点是关于thinkphp、行为扩展、插件、thinkPHP3.2.2框架行为扩展及demo示例 的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

ThinkPHP实战
ThinkPHP实战原书超清版
  • 类型:ThinkPHP大小:28.5 MB格式:PDF出版:清华大学出版社作者:夏磊
立即下载

更多PHP相关的学习资源可以参阅 PHP电子书程序设计电子书 等栏目。

ThinkPHP中的行为扩展和插件

原理分析

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

Hook中exec方法定义如下:

static public function exec($name, $tag,&$params=NULL) {
    if(false === strpos($name,'\\')) {
      // 插件(多个入口)
      $class  = "Addons\\{$name}\\{$name}Addon";
    }else{
      // 行为扩展(只有一个run入口方法)
      $class  = $name.'Behavior';
      $tag  =  'run';
    }
    $addon  = new $class();
    return $addon->$tag($params);
  }

ThinkPHP中的行为

加载标签与类之间的对应关系

// 加载模式行为定义

if(isset($mode['tags'])) {
  Hook::import(is_array($mode['tags'])?$mode['tags']:include $mode['tags']);
}
// 加载应用行为定义
if(is_file(CONF_PATH.'tags.php'))
  // 允许应用增加开发模式配置定义
  Hook::import(include CONF_PATH.'tags.php');    

模式行为对应关系

在ThinkPHP/Mode/common.php中tags标签中定义

'tags' => array(
    'app_begin'   => array(
      'Behavior\ReadHtmlCache', // 读取静态缓存
    ),
    'app_end'    => array(
      'Behavior\ShowPageTrace', // 页面Trace显示
    ),
    'view_parse'  => array(
      'Behavior\ParseTemplate', // 模板解析 支持PHP、内置模板引擎和第三方模板引擎
    ),
    'template_filter'=> array(
      'Behavior\ContentReplace', // 模板输出替换
    ),
    'view_filter'  => array(
      'Behavior\WriteHtmlCache', // 写入静态缓存
    ),
  )

应用行为对应关系

在Application/Common/Conf/tags.php中定义

调用相应的行为

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

如Hook::listen('app_begin')相当于调用Behavior\ReadHtmlCache中的run方法。找到该类,可以查看其对应的run方法如下

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

自定义行为

1.在Application/Common/Conf/tags.php中添加对应关系

'dqs_behavior'=>array('Common\Behavior\Dqs')

将对应关系添加到tags.php,程序会自动将其加载到Hook的$tags变量中,当然也可通过使用Hook中的add方法手动加载。

2.定义Common\Behavior\DqsBehavior类

<?php
namespace Common\Behavior;
use Think\Behavior;

defined('THINK_PATH') or exit();

class DqsBehavior extends Behavior {

  public function run(&$content){
    echo '<pre>';
    print_r('调用了行为Dqs');
    echo '</pre>';
  }
}

其中Behavior 类为ThinkPHP自带的抽象类

3.调用行为

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

效果如下图

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

自定义插件

1.定义插件文件

通过查看Hook文件中插件类实例化方式($class = "Addons\\{$name}\\{$name}Addon";),可以得知,如果想定义一个名为Dqs的插件,应该在Addons/Dqs目录下定义DqsAddon.class.php文件。程序如下:

<?php
namespace Addons\Dqs;
class DqsAddon{  
  public $info = array(
      'name'=>'Editor',
      'title'=>'dqs测试插件',
      'description'=>'主要用于输出',
      'status'=>1,
      'author'=>'lidequan',
      'version'=>'0.1'
  );
  public function dqsTrace($pa){
    echo '<pre>';
    print_r($pa);
    echo '</pre>';
  }
}

2.注册插件

所谓的注册插件,就是将插件的标签与类之间的对应关系,添加到Hook类中静态变量$tags中。对应行为来说,标识符仅仅是一个标识符,可以定义任意的标识符,但是对应插件来说,标识符不能随意定义,因为插件的标识符代表的是插件的方法名。所以上面的插件注册代码如下

\Think\Hook::add('dqsTrace',array('Dqs'));

3.调用插件

$params=array('name'=>'dqs');
\Think\Hook::listen('dqsTrace',$params);

效果如下

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

以上这篇老生常谈ThinkPHP中的行为扩展和插件(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持码农之家。

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程序设计有所帮助。

以上就是本次给大家分享的关于PHP的全部知识点内容总结,大家还可以在下方相关文章里找到thinkPHP5.0框架验证码及点击、 php调用快递鸟接口实例分、 PHP7引入的"??"和"?:"的、 等php文章进一步学习,感谢大家的阅读和支持。

上一篇:phpStudy2018安装、配置方法详解

下一篇:php实现微信中图片回复功能

展开 +

收起 -

相关电子书
学习笔记
网友NO.923626

基于thinkPHP3.2实现微信接入及查询token值的方法

本文实例讲述了基于thinkPHP3.2实现微信接入及查询token值的方法。分享给大家供大家参考,具体如下: 1.在con.fig文件里面配置TOKEN,APPID,APPSECRET值 2.控制器WeixinController代码: ?php/** * 微信父类控制器 * @author Songle * */namespace Weixin\Controller;use Think\Controller;class WeixinController extends Controller { private $last_time=null; private $appid=null; private $appsecret=null; function __construct(){ parent::__construct(); $token=C('TOKEN'); $this-appid=C('APPID'); $this-appsecret=C('APPSECRET'); //获取微信服务器GET请求的4个参数 $signature = I('signature'); $timestamp = I('timestamp'); $nonce = I('nonce'); $echostr = I('echostr'); if (! empty ( $echostr) ! empty ( $signature ) ! empty ($nonce )) { //定义一个数组,存储其中3个参数,分别是timestamp,nonce和token $tempArr = array($nonce,$timestamp,$token); //进行排序 sort($tempArr,SORT_STRING); //将数组转换成字符串 $tmpStr = imp……

网友NO.129457

thinkPHP5框架整合plupload实现图片批量上传功能的方法

本文实例讲述了thinkPHP5框架整合plupload实现图片批量上传功能的方法。分享给大家供大家参考,具体如下: 在官网下载plupload http://http//www.plupload.com 或者点击此处本站下载。 这里我们使用的是 pluploadQueue 在HTML页面引入相应的css和js,然后根据示例代码修改为自己的代码 link rel="stylesheet" href="/assets/plupupload/css/jquery.plupload.queue.css" rel="external nofollow" type="text/css" media="screen" /div class="form-box-header"h3{:lang('photo')}/h3/divdiv class="t-d-in-editor" div class="t-d-in-box" div id="uploader" p{:lang('plupupload_tip')}/p /div div id="uploaded"/div /div/divscript type="text/javascript" src="/assets/plupupload/plupload.full.min.js"/scriptscript type="text/javascript" src="/assets/plupupload/jquery.plupload.queue.js"/scriptscript type="text/javascript"$(function() {// Setup html5 version$("#uploader").pluploadQueue({// General settingsruntimes : 'html5,flash,silverlight,html4',ur……

网友NO.437385

thinkPHP实现基于ajax的评论回复功能

本文实例讲述了thinkPHP实现基于ajax的评论回复功能。分享给大家供大家参考,具体如下: 控制器代码: ?phpnamespace Home\Controller;use Think\Controller;class IndexController extends Controller { public function index(){ $num = M('comment')-count(); //获取评论总数 $this-assign('num',$num); $data=array(); $data=$this-getCommlist();//获取评论列表 $this-assign("commlist",$data); $this-display('index'); } /** *添加评论 */ public function addComment(){ $data=array(); if((isset($_POST["comment"]))(!empty($_POST["comment"]))){ $cm = json_decode($_POST["comment"],true);//通过第二个参数true,将json字符串转化为键值对数组 $cm['create_time']=date('Y-m-d H:i:s',time()); $newcm = M('comment'); $id = $newcm-add($cm); $cm["id"] = $id; $data = $cm; $num = M('comment')-count();//统计评论总数 $data['num']= $num; }else{ $data["error"] = "0"; } echo json_encode($data); } /** *递归获取评论列表 */ protected function getCommlis……

网友NO.586278

thinkPHP线上自动加载异常与修复方法实例分析

本文实例讲述了thinkPHP线上自动加载异常与修复方法。分享给大家供大家参考,具体如下: 项目遇到一个奇怪的问题,本地代码正常,服务器上却不正常。 经过测试,应该是自动加载出了问题,尝试了各种方法, 1.手动加载,发现好麻烦,没完没了。 2.自己写自动加载,写不出来,尴尬。 3.修改配置,使其支持自动加载,发现还是不行。 后来进行调试, 发现本地支持 import('@.ORG.OSS\OssClient');import('@.ORG.OSS\Core\OssUtil'); 而服务器上,不支持这种斜杠的方式,却支持.的方式 后来就把thinkphp核心代码,进行调整。 // 根据自动加载路径设置进行尝试搜索$paths = explode(',',C('APP_AUTOLOAD_PATH'));foreach ($paths as $path){ $class = str_replace("\\",".",$class); // dump($class); if(import($path.'.'.$class)){ // dump($path.'.'.$class); // 如果加载类成功则返回 return ; }} 经过这个小小的动作,可以了,服……

<
1
>

Copyright 2018-2020 xz577.com 码农之家

电子书资源由网友、会员提供上传,本站记录提供者的基本信息及资源来路

鸣谢: “ 码小辫 ” 公众号提供回调API服务、“ 脚本CDN ”提供网站加速(本站寻求更多赞助支持)

版权投诉 / 书籍推广 / 赞助:520161757@qq.com

上传资源(网友、会员均可提供)

查看最新会员资料及资源信息