1. 名詞解析php
官方解析: 來自 http://document.thinkphp.cn/manual_3_2.html#behavior_extend html
行爲(Behavior)是一個比較抽象的概念,你能夠想象成在應用執行過程當中的一個動做或者處理,在框架的執行流程中,各個位置均可以有行爲產生,例如路由檢測是一個行爲,靜態緩存是一個行爲,用戶權限檢測也是行爲,大到業務邏輯,小到瀏覽器檢測、多語言檢測等等均可以當作是一個行爲,
甚至說你但願給你的網站用戶的第一次訪問彈出Hello,world!這些均可以當作是一種行爲,行爲的存在讓你無需改動框架和應用,而在外圍經過擴展或者配置來改變或者增長一些功能。 而不一樣的行爲之間也具備位置共同性,好比,有些行爲的做用位置都是在應用執行前,有些行爲都是在模板輸出以後,咱們把這些行爲發生做用的位置稱之爲標籤(位),當應用程序運行到這個標籤的時候,就會被攔截下來,統一執行相關的行爲,
相似於AOP編程中的「切面」的概念,給某一個切面綁定相關行爲就成了一種類AOP編程的思想。
1. 1 標籤位置web
1) 系統核心提供的標籤位置包括下面幾個(按照執行順序排列):ajax
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 應用結束標籤位
2) 自定義thinkphp
行爲定義: 經過{Common,Module}\Conf\tags.php配置文件定義,格式以下:編程
<?php return array( 'action_begin'=>array('Home\\Behaviors\\test','Home\\Behaviors\\test1'),//一個標籤位能夠有多個行爲,使用數組便可。 // 若是是3.2.1以上版本 則須要改爲 'action_begin'=>array('Home\\Behaviors\\testBehavior','Home\\Behaviors\\test1Behavior') );
開發人員還能夠在應用中添加本身的應用標籤。數組
好比在控制器的_initialize方法中:瀏覽器
\Think\Hook::add('action_begin','Home\\Behaviors\\test1');//同時添加多個行爲,只要將第二個參數換成數組便可。 // 3.2.1以上版本 須要改爲 // \Think\Hook::add('action_begin','Home\\Behaviors\\test1Behavior');
1.2 觸發緩存
行爲的觸發: 只要在合適的地方經過如下代碼bash
\Think\Hook::listen('標籤名'[,參數]); // 或者 // tag('標籤名'[,參數]);
2. 使用場景
參考 1. 咱們已經知道 行爲 是類AOP編程的思想。除業務以外的操做,都可加入行爲。好比日誌,統計等。
3. 使用案例
3.1 全局或者模塊登陸校驗
修改 tags.php
return [ // 應用初始化 'app_init' => [], // 應用開始 'app_begin' => [ "Collection\Behavior\TestBehavior" ], // 模塊初始化 'module_init' => [], // 操做開始執行 'action_begin' => [ "\Behavior\AuthBehavior" ], // 視圖內容過濾 'view_filter' => [], // 日誌寫入 'log_write' => [], // 應用結束 'app_end' => [], ];
Collection 是模塊目錄, Application/Collection/Behavior/TestBehavior 記錄訪問日誌
<?php namespace Collection\Behavior; use Think/Log; class TestBehavior { public function run() { Log::write("有人訪問"); } }
ThinkPHP\Library\Behavior\AuthBehavior 操做認證
<?php namespace Behavior; class AuthBehavior { public function run() { $session_id = basename(strtolower(__MODULE__).'_admin_id'); $authAdminId = session($session_id); $login_url = __MODULE__ . '/Public/login'; preg_match("/(login|createVerify)/i", $_SERVER["REQUEST_URI"],$matches); $is_login = ($matches && count($matches) > 0) ? true : false; $is_get = ($_SERVER['REQUEST_METHOD'] == 'GET') ? true : false; // var_dump($authAdminId, $is_get, $is_login);exit; if (!$authAdminId && (!$is_login && $is_get)) { $timestamp = I('get._'); if ($timestamp) { // ajax echo bjuiAjaxReturn(301, '請您先登陸', '', '', '', true); exit; } else { // // $this->error('請您先登陸', __MODULE__ . '/Public/login'); header('Content-type:text/html;charset=utf-8'); redirect($login_url, 2, '請您先登陸'); } } } }
------ 未完待續 ------