thinkphp5.1--鉤子和行爲

原文鏈接:https://www.kancloud.cn/manual/thinkphp5_1/354129

行爲

ThinkPHP中的行爲是一個比較抽象的概念,可以把行爲想象成在應用執行過程中的一個動作。

在框架的執行流程中,例如路由檢測是一個行爲,靜態緩存是一個行爲,用戶權限檢測也是行爲,大到業務邏輯,小到瀏覽器檢測、多語言檢測等等都可以當做是一個行爲,甚至說你希望給你的網站用戶的第一次訪問彈出Hello,world!這些都可以看成是一種行爲,把這些行爲抽離出來的目的是爲了讓你無需改動框架和應用,而在外圍通過擴展或者配置來改變或者增加一些功能。

鉤子

不同的行爲之間也具有位置共同性,比如,有些行爲的作用位置都是在應用執行前,有些行爲都是在模板輸出之後,我們把這些行爲發生作用的位置稱之爲鉤子

當應用程序運行到這個鉤子的時候,就會被攔截下來,統一執行相關的行爲

一個鉤子可以註冊多個行爲,執行到某個鉤子位置後,會按照註冊的順序依次執行相關的行爲。但在某些特殊的情況下,你可以設置某個鉤子只能執行一次行爲,又或者你可以在一個鉤子的某個行爲中返回false來強制終止後續的行爲執行;一個行爲可以同時註冊到多個不同的鉤子上,完全看應用的需求來設計。

設置鉤子:

Hook::listen('鉤子名稱','參數','是否只有一次有效返回值');

除了鉤子名稱之外,其它參數都是可選的,注意5.1版本第二個參數不支持引用傳值。

行爲定義

行爲類的定義很簡單,一般來說只需要定義一個行爲入口方法run即可

可以在行爲方法中使用依賴注入

行爲類並不需要繼承任何類,相對比較靈活。如果行爲類需要綁定到多個鉤子,可以定義多個方法

行爲綁定

行爲定義完成後,就需要綁定到某個標籤位置才能生效,否則是不會執行的。

使用think\facade\Hook類的add方法註冊行爲,例如:

// 註冊 app\index\behavior\CheckLang行爲類到app_init標籤位
Hook::add('app_init','app\\index\\behavior\\CheckLang'); 
//註冊 app\admin\behavior\CronRun行爲類到app_init標籤位
Hook::add('app_init','app\\admin\\behavior\\CronRun');

如果要批量註冊行爲的話,可以使用:

Hook::add('app_init',['app\\index\\behavior\\CheckAuth','app\\index\\behavior\\CheckLang','app\\admin\\behavior\\Cr

 當應用運行到app_init標籤位的時候,就會依次調用app\index\behavior\CheckAuthapp\index\behavior\CheckLangapp\admin\behavior\CronRun行爲。如果其中一個行爲中有中止代碼的話則後續不會執行,如果返回false則當前標籤位的後續行爲將不會執行,但應用將繼續運行。

 

閉包支持

可以不用定義行爲直接把閉包函數綁定到某個標籤位,例如:

Hook::add('app_init',function(){ 
    echo 'Hello,world!';
});

如果標籤位有傳入參數的話,閉包也可以支持傳入參數,例如:

Hook::listen('action_init',$params);
Hook::add('action_init',function($params){ 
    var_dump($params);
});

直接執行行爲

如果需要,也可以不綁定行爲標籤,直接調用某個行爲,使用:

// 執行 app\index\behavior\CheckAuth行爲類的run方法 並引用傳入params參數
$result = Hook::exec('app\\index\\behavior\\CheckAuth',$params);

直接執行行爲的時候,執行的是run方法,如果需要執行行爲類的其它方法,可以使用

// 執行 app\index\behavior\CheckAuth行爲類的hello方法 並引用傳入params參數
$result = Hook::exec(['app\\index\\behavior\\CheckAuth','hello'], $params);

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章