php中鉤子(hook)的應用示例demo
阿新 • • 發佈:2017-12-13
ken get 超級 地址 import pat test func exp
我們先來回顧下原本的開發流程;
產品汪搞出了一堆需求;
當用戶註冊成功後需要發送短信、發送郵件等等;
然後聰明機智勇敢的程序猿們就一撲而上;
把這些需求轉換成代碼扔在 用戶註冊成功 和 跳轉到首頁 之間;
沒有什麽能夠阻擋;充滿創造力的猿們;
<?php
class Test{
public function index(){
// 用戶註冊成功
/*
此處是一堆發送短信的代碼
*/
/*
此處是一堆發送郵件的代碼
*/
/*
此處是一堆其他功能的代碼
*/
// 前往網站首頁
}
}
$test=new Test();
$test->index();
PHP
如果每個功能都由不同的猿完成的話;
首先面臨的就是代碼會很雜亂;配合起來會比較麻煩;
那封裝成函數吧;一方面會規範整潔寫;另外方便重復調用;
沒有什麽能夠阻擋;充滿創造力的猿們;
<?php
class Test{
public function index(){
// 用戶註冊成功
// 發送短信
sendSms($phone);
// 發送郵件
sendSms($email);
// 其他操作...
// 前往網站首頁
}
}
/**
* 發送短信通知
* @param integer $phone 手機號
*/
function sendSMS($phone){
// 此處是發送短信的代碼
}
/**
* 發送郵件通知
* @param string $email 郵箱地址
*/
function sendEmail($email){
// 此處是發送郵件的代碼
}
PHP
這時候運營喵表示;
如果能在後臺點點按鈕就能設置是發郵件還是發短信;那想必是極好的;
沒有什麽能夠阻擋;充滿創造力的猿們;
<?php
class Test{
public function index(){
// 用戶註冊成功
if (‘如果設置了發送短信‘) {
// 發送短信
sendSms($phone);
}
if (‘如果設置了發送郵件‘) {
// 發送郵件
sendSms($email);
}
// 其他操作...
// 前往網站首頁
}
}
/**
* 發送短信通知
* @param integer $phone 手機號
*/
function sendSMS($phone){
// 此處是發送短信的代碼
}
/**
* 發送郵件通知
* @param string $email 郵箱地址
*/
function sendEmail($email){
// 此處是發送郵件的代碼
}
PHP
在一個封閉企業環境下這樣搞是沒有問題的;
然鵝;我們還有一位開放無私的猿領導要把程序開源出去造福其他猿類;
希望有更多的猿類來參與這個項目;共同開發功能;
如果大家都去改動這套程序;把自己的代碼扔在 用戶註冊成功 和 跳轉到首頁 之間;
這顯然是不靠譜的;想想都混亂的一塌糊塗;
那可不可以大家把自己寫的代碼放到某個目錄下;
然後系統自動的根據配置項把這些代碼加載到 用戶註冊成功 和 跳轉到首頁 之間呢?
好先定義如下目錄
├─plugin // 插件目錄
│ ├─plugin1 // 插件1
│ │ ├─config.php // 插件1的配置項
│ │ ├─index.php // 插件1的程序處理內容
│ ├─plugin2
│ │ ├─config.php
│ │ ├─index.php
│ ├─plugin3
│ │ ├─config.php
│ │ ├─index.php
│ ├─...
├─index.php // 業務邏輯
PHP
業務邏輯的代碼:
<?php
class Test{
public function index(){
// 用戶註冊成功
// 獲取全部插件
$pluginList=scandir(‘./plugin/‘);
// 循環插件 // 排除. ..
foreach ($pluginList as $k => $v) {
if ($v==‘.‘ || $v==‘..‘) {
unset($pluginList[$k]);
}
}
echo "簡易後臺管理<hr>";
// 插件管理
foreach ($pluginList as $k => $v) {
// 獲取配置項
$config=include ‘./plugin/‘.$v.‘/config.php‘;
$word=$config[‘status‘]==1 ? ‘點擊關閉‘ : ‘點擊開啟‘;
echo $config[‘title‘].‘<a href="./index.php?change=‘.$v.‘">‘.$word.‘</a><br />‘;
}
echo ‘<hr>‘;
// 輸出插件內容
foreach ($pluginList as $k => $v) {
// 獲取配置項
$config=include ‘./plugin/‘.$v.‘/config.php‘;
if ($config[‘status‘]==1) {
include ‘./plugin/‘.$v.‘/index.php‘;
// 運行插件
Hook::run($v);
}
}
// 前往網站首頁
}
}
// 插件類
class Hook{
// 註冊添加插件
public static function add($name,$func){
$GLOBALS[‘hookList‘][$name][]=$func;
}
// 執行插件
public static function run($name,$params=null){
foreach ($GLOBALS[‘hookList‘][$name] as $k => $v) {
call_user_func($v,$params);
}
}
}
// 更改插件狀態
if (isset($_GET[‘change‘])) {
// 獲取到配置項
$config=include ‘./plugin/plugin‘.