当前位置:首页 > CMS教程 > Thinkphp > 列表

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

发布:smiling 来源: PHP粉丝网  添加日期:2021-03-23 11:46:05 浏览: 评论:0 

这篇文章主要介绍了ThinkPHP行为扩展Behavior应用实例,对于读者深入了解ThinkPHP框架程序设计大有帮助,需要的朋友可以参考下

本文以实例的形式详细介绍了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

  1. // 行为扩展定义 
  2. 'tags' => array
  3. 'app_init'   => array
  4. ), 
  5. 'app_begin'   => array
  6.   'Behavior\ReadHtmlCache'// 读取静态缓存 
  7. ), 
  8. 'app_end'    => array
  9.   'Behavior\ShowPageTrace'// 页面Trace显示 
  10. ), 
  11. 'path_info'   => array(), 
  12. 'action_begin' => array(), 
  13. 'action_end'  => array(), 
  14. 'view_begin'  => array(), 
  15. 'view_parse'  => array
  16.   'Behavior\ParseTemplate'// 模板解析 支持PHP、内置模板引擎和第三方模板引擎 
  17. ), 
  18. 'template_filter'=> array
  19.   'Behavior\ContentReplace'// 模板输出替换 
  20. ), 
  21. 'view_filter'  => array
  22.   'Behavior\WriteHtmlCache'// 写入静态缓存 
  23. ), 
  24. 'view_end'   => array(), 
  25. ), 

默认调用了系统行为扩展:静态缓存读取 、页面Trace显示输出、模板解析、模板内容输出替换、静态缓存写入

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

分别用Hook去加载 系统行为和自定义行为,并把配置信息保存到 Hook 私有属性$tags中

ThinkPHP\Library\Think\Think.class.php 初始化完成后会调用App::run();

ThinkPHP\Library\Think\App.class.php文件如下:

  1. /** 
  2. * 运行应用实例 入口文件使用的快捷方法 
  3. * @access public 
  4. * @return void 
  5. */ 
  6. static public function run() { 
  7. // 应用初始化标签 
  8. Hook::listen('app_init'); 
  9. App::init(); 
  10. // 应用开始标签 
  11. Hook::listen('app_begin'); 
  12. // Session初始化 
  13. if(!IS_CLI){ 
  14.   session(C('SESSION_OPTIONS')); 
  15. // 记录应用初始化时间 
  16. G('initTime'); 
  17. App::exec(); 
  18. // 应用结束标签 
  19. Hook::listen('app_end'); 
  20. return ; 

可以看出程序在App init之前 通过钩子去监听(查看)此动作时是否有需要处理的。循环$tags['app_init']获取类名并通过类名自动执行行为扩展类run方法

所有钩子如下:

  1. 'url_dispatch'     // URL调度结束标签 
  2. 'app_init'     // 应用初始化标签 
  3. 'app_begin'     // 应用开始标签 
  4. 'app_end'     // 应用结束标签 
  5. 'action_begin'     // 动作执行前操作 
  6. 'action_end'     // 动作执行后操作    
  7. 'ajax_return'     // 用于扩展其他返回格式数据 
  8. 'path_info'       // 检测路由规则 如果没有则按默认规则调度URL 
  9. 'template_filter'    // 模版编译过滤标签 
  10. 'view_begin'      // 视图开始标签 
  11. 'view_end'       // 视图结束标签 
  12. 'view_parse'      // 视图解析标签 
  13. 'view_filter'      // 内容过滤标签 

缺点如下:

1.顺序不可控(配置文件没有专门的参数去控制顺序)如app_init同时有2个监控时先调用哪个方法。

2.监控不是全局监控内部写的太死只有一些定义好的不能通过配置文件去自动控制每一个操作的钩子(可能是考虑到性能才没有加)

优点如下:

1.可以实现了好多行为扩展

2.可以代理检测、浏览器防刷新检测、操作路由检测等

总结:

行为扩展就是在 程序某个操作时去额外的去执行某一特定功能。如程序在操作数据库 读的时候 通过explian获取性能信息并监测性能瓶颈 如出现获取数据时超过特定秒数 就把相关信息email给项目经理等。

Tags: Behavior

分享到: