我們先來回顧下原本的開發流程;
產品汪搞出了一堆需求;
當用戶注冊成功后需要發送短信、發送郵件等等;
然后聰明機智勇敢的程序猿們就一撲而上;
把這些需求轉換成代碼扔在 用戶注冊成功 和 跳轉到首頁 之間;
沒有什么能夠阻擋;充滿創造力的猿們;
<?php class Test{ public function index(){ // 用戶注冊成功 /* 此處是一堆發送短信的代碼 */ /* 此處是一堆發送郵件的代碼 */ /* 此處是一堆其他功能的代碼 */ // 前往網站首頁 } } $test=new Test(); $test->index();
如果每個功能都由不同的猿完成的話;
首先面臨的就是代碼會很雜亂;配合起來會比較麻煩;
那封裝成函數吧;一方面會規范整潔寫;另外方便重復調用;
沒有什么能夠阻擋;充滿創造力的猿們;
<?php class Test{ public function index(){ // 用戶注冊成功 // 發送短信 sendSms($phone); // 發送郵件 sendSms($email); // 其他操作... // 前往網站首頁 } } /** * 發送短信通知 * @param integer $phone 手機號 */ function sendSMS($phone){ // 此處是發送短信的代碼 } /** * 發送郵件通知 * @param string $email 郵箱地址 */ function sendEmail($email){ // 此處是發送郵件的代碼 }
這時候運營喵表示;
如果能在后台點點按鈕就能設置是發郵件還是發短信;那想必是極好的;
沒有什么能夠阻擋;充滿創造力的猿們;
<?php class Test{ public function index(){ // 用戶注冊成功 if ('如果設置了發送短信') { // 發送短信 sendSms($phone); } if ('如果設置了發送郵件') { // 發送郵件 sendSms($email); } // 其他操作... // 前往網站首頁 } } /** * 發送短信通知 * @param integer $phone 手機號 */ function sendSMS($phone){ // 此處是發送短信的代碼 } /** * 發送郵件通知 * @param string $email 郵箱地址 */ function sendEmail($email){ // 此處是發送郵件的代碼 }
在一個封閉企業環境下這樣搞是沒有問題的;
然鵝;我們還有一位開放無私的猿領導要把程序開源出去造福其他猿類;
希望有更多的猿類來參與這個項目;共同開發功能;
如果大家都去改動這套程序;把自己的代碼扔在 用戶注冊成功 和 跳轉到首頁 之間;
這顯然是不靠譜的;想想都混亂的一塌糊塗;
那可不可以大家把自己寫的代碼放到某個目錄下;
然后系統自動的根據配置項把這些代碼加載到 用戶注冊成功 和 跳轉到首頁 之間呢?
好先定義如下目錄
├─plugin // 插件目錄 │ ├─plugin1 // 插件1 │ │ ├─config.php // 插件1的配置項 │ │ ├─index.php // 插件1的程序處理內容 │ ├─plugin2 │ │ ├─config.php │ │ ├─index.php │ ├─plugin3 │ │ ├─config.php │ │ ├─index.php │ ├─... ├─index.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'.substr(