本文实例讲述了Thinkphp 框架扩展之行为扩展原理与实现方法。分享给大家供大家参考,具体如下:
系统核心提供的标签位置包括下面几个(按照执行顺序排列):
app_init | 应用初始化标签位 |
path_info | PATH_INFO检测标签位 |
app_begin | 应用开始标签位 |
action_name | 操作方法名标签位 |
action_begin | 控制器开始标签位 |
view_begin | 视图输出开始标签位 |
view_parse | 视图解析标签位 |
template_filter | 模板内容解析标签位 |
view_filter | 视图输出过滤标签位 |
view_end | 视图输出结束标签位 |
action_end | 控制器结束标签位 |
app_end | 应用结束标签位 |
在每个标签位置,可以配置多个行为定义,行为的执行顺序按照定义的顺序依次执行。除非前面的行为里面中断执行了(某些行为可能需要中断执行,例如检测机器人或者非法执行行为),否则会继续下一个行为的执行。 行为定义: 通过Common\Conf\tags.php配置文件定义,格式如下:
1
2
3
4
|
<?php return array ( 'action_begin' => array ( 'Home\\Behaviors\\TestBehavior' , 'Home\\Behaviors\\Test1Behavior' ), ); |
上面注册了两个行为,分别是Home模块下的test和test1行为,类文件位于Home模块目录下的Behaviors目录,可以自定义目录。
行为必须是一个包含命名空间路径的类,如上的 Home\Behaviors\TestBehavior 对应的类是 Home/Behaviors/TestBehavior.class.php。
除了这些系统内置标签之外,开发人员还可以在应用中添加自己的应用标签。 比如在控制器的_initialize方法中:
1
2
|
\Think\Hook::add( 'action_begin' , 'Home\\Behaviors\\TestBehavior' ); //同时添加多个行为,只要将第二个参数换成数组即可。 |
行为类的定义,以上面的test行为为例:
1
2
3
4
5
6
7
8
|
<?php namespace Home\Behaviors; class TestBehavior extends \Think\Behavior{ //行为执行入口 public function run(& $param ){ } } |
行为类建议继承\Think\Behavior,必须实现run(&$param)
方法,行为是通过这个方法执行的。
行为的触发: 只要在合适的地方通过以下代码
1
2
3
|
当应用执行到这个地方的时候将自动触发指定标签名下的所有行为类。
isten方法可以传入并且只接受一个参数,如果需要传入多个参数,请使用数组,该参数为引用传值,所以只能传入变量。 参数可以被run(&$param)
中的$param
接收。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/qq_42176520/article/details/81072423