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

本文实例讲述了thinkPHP中钩子的两种配置调用方法。分享给大家供大家参考,具体如下:

thinkphp的钩子行为类是一个比较难以理解的问题,网上有很多写thinkphp钩子类的文章,我也是根据网上的文章来设置thinkphp的钩子行为的,但根据这些网上的文章,我在设置的过程中,尝试了十几次都没有成功,不过,我还是没有放弃,最后还是在一边调节细节,一边试验的过程中实现了钩子行为的设置。下面是我个人的设置经验,在这里跟大家分享一下。

个人做了两种设置,都试验成功了,一个简单点,在thinkphp的核心文件中模仿核心行为类添加了另一个行为类,下面是截图:

我的虚拟主机配置文件夹是D:/think

Thinkphp是tp框架文件夹,配置过tp框架应该都知道Library是tp放核心文件的文件夹,Behavior文件夹则是tp的钩子行为类文件的核心文件夹,里面放置着很多行为类文件,我只是模仿这些钩子行为类文件在里面建了一个钩子行为类文件adBehavior.class.php,内容如下:

<?php namespace Behavior; class adBehavior{ function run($arg){ //在此介绍下,run必须的 ,细心的会在Think核心找到Behavior.class.php里面有这样一句话 abstract public function run(&$params); echo '我是一条'.$arg['name'].'广告,'.$arg['value'].'代言'; } }

设置好了自定义的钩子行为类之后,我们接下来就要利用这个钩子行为类促发钩子的行为了,```钩子的行为```说白了其实就是促发钩子行为类的run方法里面的代码执行,我这里只是简单的输出run方法参数的内容,在应用中的,大家可以自由发挥。

下面是促发行为的操作:

解释一下:我这里是Home模块下面的IndexController控制器的登录方法

namespace Home\Controller; use Think\Controller; use Think\Hook;//引进促发钩子行为的类,是为下面的Hook::add()调用做伏笔的 class IndexController extends Controller { public function login(){ //这里我设置一个ad行为的标签,也就是给我自定义的adBehavior钩子行为类添加一个促发行为的标识 Hook::add('ad','Behavior\\adBehavior'); //第一个是执行标签的名称,第二个参数是行为的类的地址 Hook::add('test', "Home\\Behaviors\\testBehavior"); //Hook::add('test2', "Home\\Behaviors\\testBehavior"); $param=array('name'=>'testBehavior'); $param2=array('LIS'=>'LLISTION'); $param3=array('music'=>'cangjingshikong'); $this->assign('param',$param); $this->assign('param',$param2); $this->assign('param',$param3); $this->display(); } }

下面是login模板内容:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>ThinkPHP 行为(Behavior)扩展以及插件(Plug or Hook)详解(含实例) </title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="description" content="Hook使用方法" /> </head> <body> <h1>How to used?</h1> {:hook('ad', array('name'=>'AV','value'=>'*老师'))} <div>————————————————分割线1——————————————————</div> <div style="font-weight: bold ;color: #00ff00">{:hook('ad', array('name'=>'MV','value'=>'苍井空老师'))}</div> <div>————————————————分割线2——————————————————</div> <!--hook函数第一个参数是标签的名称,第二个参数随意--> <!--tag函数第一个参数是标签的名称,第二个一定是变量,因为tag函数是引址传递的参数--> <div>hook函数:{:hook('test', array('name'=>'World'))}<hr/></div> <div>tag函数:{:tag('mv',$param)}<hr/></div> <hr/> <div>tag函数:{:tag('action_begin',$param)}</div> </body> </html>

这里的路径我就不写了吧,一般对tp框架了解的人都知道,这个模板login.html放在哪里。

关于这个模板的内容,我已经提前把下面要讲述的另一种设置钩子行为类方法的内容也放在这里了,大家可以自行测试一下调用这个模板,如果你跟着我的思路设置了,我想它应该会输出:

How to used? 我是一条AV广告,*老师代言 ————————————————分割线1—————————————————— 我是一条MV广告,苍井空老师代言 ————————————————分割线2——————————————————

呵呵,这里引用苍老师的作用,你懂的。

废话不多说,下面是第二种自己设置行为类的方法,这里我是根据tp框架的手册以及诸位网友的网文自己测试成功了的,大家按照我的思路设置就行了。只有你配置对了,我想应该不会出现太多问题。

1、首先在你的模块下面建一个文件夹Behaviors,再在Behaviors里面创建自定义的钩子行为类,钩子行为类必须是xxxBehaviors.class.php的格式。

2、其次在你的模块下面的Conf文件夹中新增一个文件tags.php。
为什么要这样,这是tp的语法,你照做就行了,当然你自己也可以探究一下。

这样子说或许还不够形象,下面我还是上代码吧,本人描述比较差。

先截个图显示路径吧,免得有的同学还是摸不着头脑。

解释一下上面的文件夹,Conf文件夹有的tp会自动生成,有的可能要你新建,Behaviors文件夹则是要你新建的,下面还是上代码:

在Behaviors文件夹里面(完整路径D:\think\application\Home\Behaviors\testBehavior.class.php)我自定义的钩子行为类的内容:

<?php /** * Created by PhpStorm. * User: Administrator * Date: 2016/7/17 * Time: 11:02 */ namespace Home\Behaviors; /* * 注册钩子行为类,要触发的行为写在run函数里 * */ class testBehavior extends \Think\Behavior{ public function run(&$arg){ echo 'test behavior=====下一行是参数<br/>'.$arg['name']; } }

在Conf文件夹里面(完整路径D:\think\application\Home\Conf\tags.php,当然这是我的情况)tags.php的内容:

<?php /** * Created by zhuowenfeng. * User: Administrator * Date: 2016/7/17 * Time: 10:56 */ return array( //'action_begin'=>array('Home\\Behaviors\\test','Home\\Behaviors\\test'), //一个标签位可以有多个行为,使用数组即可。 // 如果是3.2.1版本 则需要改成 'action_begin'=>array('Home\\Behaviors\\testBehavior','Home\\Behaviors\\testBehavior'), 'mv'=>array('Home\\Behaviors\\mvBehavior','Home\\Behaviors\\mvBehavior') );

解释一下,上面tags.php文件的内容,我配置了两个行为标识,``action_begin``,``mv``,是跟login.html那里相对应的,你可以回去仔细查看一下,login.html模板的内容,必定包含有``action_begin``,``mv``,这里也是tp框架在tags.php设置行为标识的语法,要是想问为什么可以自行探究,这里不多说。

还有请注意:上面那个被我注释掉的‘action_begin',其实是我的版本不适合这个语法,这是其他版本在tags.php配置行为标识的语法,这里tp里面的文档说的比较清楚,我就不多说了。如果,你的版本和我不同,那么请用上面的语法尝试一下,如果用上面的语法配置还是没办法配置成功,那么可能是你配置错了。

配置好了,那么请你再尝试调用模板login.html。我相信你一定能获得你想要的配置结果的。

这里提醒一句,请认真看我所做的注释,那里可以说也包含了很多信息。

接下来,我要讲讲设置监听钩子行为类的两个方法hook(),tag():

这两个函数都是tp内置监听钩子行为类的内置函数,可以在tp框架的函数库functions.php文件中找得到。这里只讲他们的调用区别,其实已经在login.html模板文件中提到了,这里就再次说明一下:

两个函数在functions.php的代码:

/** * 获取和设置配置参数 支持批量定义 * @param string|array $name 配置变量 * @param mixed $value 配置值 * @param mixed $default 默认值 * @return mixed */ function hook($hook,$params=array()){ \Think\Hook::listen($hook,$params); //监听一个钩子 } /** * 处理标签扩展 * @param string $tag 标签名称 * @param mixed $params 传入参数 * @return void */ function tag($tag, &$params=NULL) { \Think\Hook::listen($tag,$params); }

之所以在这里展示一下这两个函数的内容,是为了解释它们的区别:

细心的你应该发现tag函数的$param参数值里前面带了一个···&···符号,没有错:这个符号就是引用变量的地址符号,所以tag函数的$param参数只能是变量,请不要怀疑,你可以测试一下不是变量的情况,呵呵。

它们的区别也在于此,hook可以引用任何参数,tag只能引用变量的参数

上面那个tags.php文件里面我在每个标签行为的后面都重复配置了testBehavior自定义类,是为了证明,一个标签也可以对应多个行为类,如果你配置成功了,那么你运行login.html的时候,肯定发现login根据testBehavior设置的执行了两次。

最后,总结一下:

其实,我想说,tp框架的钩子行为类无非就是为了在某个特定地点,特定时间促发某种行为,这个是应用很广的,本人姑且这么认为。比如,你想要在某个模板植入广告,可以向我这样子简单的设置。

然后,简单的介绍tp行为的引用步骤:

首先第一步,你要先配置好自己的行为类,这是毋庸置疑的。

其次是促发的行为,你必须在你自定义的行为类的run里面设置,在这里实现你的任何行为,run方法就是你配置行为的地方。

然后,就是配置tags.php的行为标识了,这里你可以按照上面格式配置,当然,你有没有细心的发现上面的IndexController.class.php里面我多写了几行代码:

//第一个是执行标签的名称,第二个参数是行为的类的地址 Hook::add('test', "Home\\Behaviors\\testBehavior");

其实这里是动态添加行为标识的代码,也就是说,钩子行为的标签行为,也就是标识也可以动态添加的,你可以试试。

最后,就是监听行为了,监听行为就是引用tag方法或者hook方法了,在这里你可以传入参数,也可不传,看你想怎么做了。监听行为你可以在模板上监听,也可以在其他地方监听,比如控制器的方法中,这里就不举例了,你可以自己试试,我之所以在模板中举例,完全是为了看到效果,毕竟做实验看不到你要的结果,是证明不了你的实验是个成功的实验的。

多说一句,本人比较粗心,假如有什么 文字错误 还请指出,或者自己脑补 ,呵呵。

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《smarty模板入门基础教程》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

时间: 2024-10-27 09:23:57

thinkPHP中钩子的两种配置调用方法详解的相关文章

thinkPHP中钩子的两种配置调用方法详解_php实例

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

Android 中倒计时验证两种常用方式实例详解

Android 中倒计时验证两种常用方式实例详解 短信验证码功能,这里总结了两种常用的方式,可以直接拿来使用.看图: 说明:这里的及时从10开始,是为了演示的时间不要等太长而修改的. 1.第一种方式:Timer /** * Description:自定义Timer * <p> * Created by Mjj on 2016/12/4. */ public class TimeCount extends CountDownTimer { private Button button; //参数依

ThinkPHP中Widget扩展的两种写法及调用方法详解

本文实例讲述了ThinkPHP中Widget扩展的两种写法及调用方法.分享给大家供大家参考,具体如下: Widget扩展一般用于页面组件的扩展,在页面根据需要输出不同的内容,下面介绍一下ThinkPHP中Widget的两种写法及调用 写法一: ArticlWidget.class.php文件: class ArticleWidget extends Widget { /** * * @param array $data * @return type * 调用方法:{:W('ArticleList

Android中gson、jsonobject解析JSON的方法详解_Android

JSON的定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据交换.JSON采用兼容性很高的文本格式,同时也具备类似于C语言体系的行为. JSON对象: JSON中对象(Object)以"{"开始, 以"}"结束. 对象中的每一个item都是一个key-value对, 表现为"key:value"的形式, ke

Android中gson、jsonobject解析JSON的方法详解

JSON的定义: 一种轻量级的数据交换格式,具有良好的可读和便于快速编写的特性.业内主流技术为其提供了完整的解决方案(有点类似于正则表达式 ,获得了当今大部分语言的支持),从而可以在不同平台间进行数据交换.JSON采用兼容性很高的文本格式,同时也具备类似于C语言体系的行为. JSON对象: JSON中对象(Object)以"{"开始, 以"}"结束. 对象中的每一个item都是一个key-value对, 表现为"key:value"的形式, ke

asp.net 函数的定义 返回值 调用方法详解说明(vb.net/c#)

asp教程.net 函数的定义 返回值 调用方法详解说明(vb.net/c#),首页我们来看一个vb.net中开的asp.net教程创建一个函数的做法,如下 <script runat="server" language="VB">       Function getName() As String         Return "a"       End Function       Sub Page_Load(s As Obje

JavaScript函数的4种调用方法详解_javascript技巧

在JavaScript中,函数是一等公民,函数在JavaScript中是一个数据类型,而非像C#或其他描述性语言那样仅仅作为一个模块来使用.函数有四种调用模式,分别是:函数调用形式.方法调用形式.构造器形式.以及apply形式.这里所有的调用模式中,最主要的区别在于关键字 this 的意义,下面分别介绍这个几种调用形式. 本文主要内容: 1.分析函数的四种调用形式2.弄清楚函数中this的意义3.明确构造函对象的过程4.学会使用上下文调用函数 一.函数调用形式 函数调用形式是最常见的形式,也是最

深入php-fpm的两种进程管理模式详解_php实例

php-fpm的两种进程管理模式php-fpm的进程数也是可以根据设置分为动态和静态的.一种是直接开启指定数量的php-fpm进程,不再增加或者减少:另一种则是开始的时候开启一定数量的php-fpm进程,当请求量变大的时候,动态的增加php-fpm进程数到上限,当空闲的时候自动释放空闲的进程数到一个下限.这两种不同的执行方式,可以根据服务器的实际需求来进行调整.这里先说一下涉及到这个的几个参数吧,他们分别是pm.pm.max_children.pm.start_servers.pm.min_sp

解决在Web.config或App.config中添加自定义配置的方法详解_实用技巧

.Net中的System.Configuration命名空间为我们在web.config或者app.config中自定义配置提供了完美的支持.最近看到一些项目中还在自定义xml文件做程序的配置,所以忍不住写一篇用系统自定义配置的随笔了.如果你已经对自定义配置了如指掌,请忽略这篇文章.言归正传,我们先来看一个最简单的自定义配置 复制代码 代码如下: <?xml version="1.0" encoding="utf-8" ?> <configura