phphook
⑴ thinkphp hook 怎麼寫
ThinkPHP3.2 擴展--鉤子,HOOK
之前寫到TP3.1的行為擴展是tag();在TP3.2中引入了另一種說法—:鉤子。
我們來看一下TP3.2中的鉤子這個東西:
一:文件流程:
1:/index.php ->require './ThinkPHP/ThinkPHP.php';
2:/ThinkPHP/ThinkPHP.php—->require CORE_PATH.'Think'.EXT; Think\Think::start();
3:/ThinkPHP/Library/Think/Think.class.php—–>App::run();
4:/ThinkPHP/Library/Think/App.class.php 。到這里基本流程就走完了,(這里不說細節);
二:代碼:
1:看一下 App::run()方法:
// 應用初始化標簽
Hook::listen('app_init');
App::init();
// 應用開始標簽
Hook::listen('app_begin');
// Session初始化
if(!IS_CLI){
session(C('SESSION_OPTIONS'));
}
// 記錄應用初始化時間
G('initTime');
App::exec();
// 應用結束標簽
Hook::listen('app_end');
return ;
其中的Hook::listen(」)就是用來執行鉤子的,我們可以在app_init這個安插的位置用來獲取應用中安裝的插件。
看一下Hook::listen();
/**
* 監聽標簽的插件
* @param string $tag 標簽名稱
* @param mixed $params 傳入參數
* @return void
*/
static public function listen($tag, &$params=NULL) {
if(isset(self::$tags[$tag])) {
if(APP_DEBUG) {
G($tag.'Start');
trace('[ '.$tag.' ] --START--','','INFO');
}
foreach (self::$tags[$tag] as $name) {
APP_DEBUG && G($name.'_start');
$result = self::exec($name, $tag,$params);
if(APP_DEBUG){
G($name.'_end');
trace('Run '.$name.' [ RunTime:'.G($name.'_start',$name.'_end',6).'s ]','','INFO');
}
if(false === $result) {
// 如果返回false 則中斷插件執行
return ;
}
}
if(APP_DEBUG) { // 記錄行為的執行日誌
trace('[ '.$tag.' ] --END-- [ RunTime:'.G($tag.'Start',$tag.'End',6).'s ]','','INFO');
}
}
return;
}
其中關鍵是:self::exec($name, $tag,$params); 看一下exec的代碼:
/**
* 執行某個插件
* @param string $name 插件名稱
* @param string $tag 方法名(標簽名)
* @param Mixed $params 傳入的參數
* @return void
*/
static public function exec($name, $tag,&$params=NULL) {
if(false === strpos($name,'\\')) {
// 插件(多個入口)
$class = "Addons\\{$name}\\{$name}Addon";
}else{
// 行為擴展(只有一個run入口方法)
$class = $name.'Behavior';
$tag = 'run';
}
$addon = new $class();
return $addon->$tag($params);
}
最後還不是 new $class();進而return $addon->$tag($params); 又轉到了具體鉤子的代碼方法。其實就是我們原本的調用class的方法,只不過經過別人的高度封裝了。
三:那麼問題來了,這個鉤子有什麼用呢? 怎麼用?
這里以OneThink 的{:hook('AdminIndex')}為例,看一些別人是怎麼用的。
在系統初始化到 Hook::listen('app_init'); 時,
把app_init的標簽位擴展了,在tags.php的配置文件中有這么個東西:用於初始化插件(或者說是獲取系統中安裝的插件)
<?php
return array(
'app_init'=>array('Common\Behavior\InitHook')
);
一看就明白,無非就是讀取持久化的信息,放到緩存或是其他的方式
// 行為擴展的執行入口必須是run
public function run(&$content){
if(isset($_GET['m']) && $_GET['m'] === 'Install') return;
$data = S('hooks');
if(!$data){
$hooks = M('Hooks')->getField('name,addons');
foreach ($hooks as $key => $value) {
if($value){
$map['status'] = 1;
$names = explode(',',$value);
$map['name'] = array('IN',$names);
$data = M('Addons')->where($map)->getField('id,name');
if($data){
$addons = array_intersect($names, $data);
Hook::add($key,$addons);
}
}
}
S('hooks',Hook::get());
}else{
Hook::import($data,false);
}
}
當在程序執行到{:hook(『AdminIndex』)}時—>調用的是Hook::listen(『AdminIndex』);
AdminIndex這個掛載點包含了三個插件:分別是:SiteStat, SystemInfo,DevTeam。
用一個循環來分別按順序執行.
總結:鉤子其實就是起到一個掛載點的作用,這個鉤子掛在哪裡,就可以在哪裡執行,內容或功能就是掛載插件或類庫的具體實現。這樣實現的代碼就有很大的靈活性,掛載點不變,掛的東西變數,功能也就相應的變化,是不是很靈活強大呀。
⑵ thinkphp hook什麼用
ThinkPHP擴展機制中比較關鍵的一項擴展,行為既可以獨立調用,也可以綁定到某個標簽中進行偵聽,官方提出的CBD模式中行為也佔了主要的地位,可見行為在ThinkPHP框架中意義非凡。
⑶ php中的hook
Prestashop Quick Primer
Prestashop Quick Primer
方便給網頁設計者了解 Prestashop的主要結構
看了前面一章的介紹文章,我想你也迫不及待想要看看主要實現的方法吧?別急,現在就開始。記得轉載的時候註明:www.jackyon.com哦!
Prestashop,像所有的PHP腳本語言一樣會載入本地伺服器上的 index.php 文件。如果你的 Prestashop 商店程序是放在mystore.com,當客戶端輸入URL : http://www.mystore.com,webserver會自動載入到index這個頁面。
為了了解咋們的prestashop shop是如何運行的,我們需要去了解下index文件是如何去工作的。
Index.php
prestashop index.php文件中包含著以下的代碼 :
1. <?php
2. include(dirname(__FILE__).'/config/config.inc.php');
3. include(dirname(__FILE__).'/header.php');
4.
5. $smarty->assign('HOOK_HOME', Mole::hookExec('home'));
6. $smarty->display(_PS_THEME_DIR_.'index.tpl');
7.
8. include(dirname(__FILE__).'/footer.php');
9.
10. ?>
在 index.php 文件的開始包含著一個 config.inc.php 的文件,這個文件時主要處理我們的主要設置還有一些程序相關其它設置,config.inc.php 會檢查是否所有的東西已經安裝好了,並且確認了我們的默認模版和默認目錄,還有路徑、訂單的狀態還有其它的一些設置。或者現在你已經在抱怨著什麼時候才能開始學習到相關的模版製作,現在我們只知道 index.php 中包含了什麼而已。
然而,作為一個網頁設計者,你可能需要及時地注意到了網頁上的錯誤信息,因此現在就要用到剛才所提到的 config.inc.php 文件了,在這個文件最上面幾行,你可以看到:
1. @ini_set('display_errors', 'off');
2. 你可以選擇把它打開或關閉
3. @ini_set('display_errors', 'on');
現在你可以關閉錯誤信息報告了。不過要注意在下次正式安裝前要吧它改回來。
下一步,來看看 header.php 的代碼:
1. <?php
2.
3. // P3P Policies (http://www.w3.org/TR/2002/REC-P3P-20020416/#compact_policies)
4. header('P3P: CP="IDC DSP COR CURa ADMa OUR IND PHY ONL COM STA"');
5.
6. require_once(dirname(__FILE__).'/init.php');
7.
8. /* CSS */
9. $css_files[_THEME_CSS_DIR_.'global.css'] = 'all';
10.
11. /* Hooks are voluntary out the initialize array (need those variables already assigned) */
12. $smarty->assign(array(
13. 'HOOK_HEADER' => Mole::hookExec('header'),
14. 'HOOK_LEFT_COLUMN' => Mole::hookExec('leftColumn'),
15. 'HOOK_TOP' => Mole::hookExec('top'),
16. 'static_token' => Tools::getToken(false),
17. 'token' => Tools::getToken(),
18. 'priceDisplayPrecision' => _PS_PRICE_DISPLAY_PRECISION_,
19. 'content_only' => intval(Tools::getValue('content_only'))
20. ));
21.
22. if(isset($css_files) AND !empty($css_files)) $smarty->assign('css_files', $css_files);
23. if(isset($js_files) AND !empty($js_files)) $smarty->assign('js_files', $js_files);
24.
25. /* Display a maintenance page if shop is closed */
26. if (isset($maintenance) AND (!isset($_SERVER['REMOTE_ADDR']) OR $_SERVER['REMOTE_ADDR'] != Configuration::get('PS_MAINTENANCE_IP')))
27. {
28. header('HTTP/1.1 503 temporarily overloaded');
29. $smarty->display(_PS_THEME_DIR_.'maintenance.tpl');
30. exit;
31. }
32.
33. $smarty->display(_PS_THEME_DIR_.'header.tpl');
34.
35. ?>
接下來我們可以看到這句代碼:
1. $smarty->assign('HOOK_HOME', Mole::hookExec('home'));
這里將會指定分配hook(我們通常都會第一時間把hook給指定分配了,你也可以指定哪些模塊在你網站中出現)
1. $smarty->display(_PS_THEME_DIR_.'index.tpl');
這一行代碼是說明 index.tpl 相當於默認主題模版目錄的位置(你可以定義或者添加你的主題,backoffice>> preferances>>appearance)
最後我們再來看看footer.php
1. include(dirname(__FILE__).'/footer.php');
這一行代碼include了我們的footer.php文件,看下footer.php文件代碼:
1. <?php
2.
3. if (isset($smarty))
4. {
5. $smarty->assign(array(
6. 'HOOK_RIGHT_COLUMN' => Mole::hookExec('rightColumn'),
7. 'HOOK_FOOTER' => Mole::hookExec('footer'),
8. 'content_only' => intval(Tools::getValue('content_only'))));
9. $smarty->display(_PS_THEME_DIR_.'footer.tpl');
10. }
11.
12. ?>
盡管我們現在了解到了程序的配置設置,hooks還有不同的php文件包含,但是你會發現,目前為止,還沒出現我們所熟悉的HTML代碼。其實這個就是我們所有templates(tpl)的來源入口。tpl文件裡麵包含著HTML還有smarty模版語言。這些tpl文件大多都在你的模版目錄下,有些也在每個功能模塊目錄下。
現在來看看header.php文件,你會看到裡面有這些代碼:
1. $css_files[_THEME_CSS_DIR_.'global.css'] = 'all';
2. if(isset($css_files) AND !empty($css_files)) $smarty->assign('css_files', $css_files);
3. if(isset($js_files) AND !empty($js_files)) $smarty->assign('js_files', $js_files);
4.
5. $smarty->display(_PS_THEME_DIR_.'maintenance.tpl'); - Will display a maintenance page called maintenance.tpl if your shop is closed */
6.
7. $smarty->display(_PS_THEME_DIR_.'header.tpl');
我們的global.css和css、javascript文件都被包含在這里,html的顯示來自於header.tpl文件。
以此類推,index.php 和footer.php也有這對應的index.tpl和footer.tpl(其它的文件也是這樣的命名規則)
現在目前看起來好像有點混亂了,不用擔心,堅持下去,接下來會變得簡單些的。
好了,從這里開始打段,總結下:index.php文件包含著header.php,index.tpl和footer.tpl,header.php和footer.php的tpl文件也分別取自他們本身的文件名。
我們主要的HTML代碼都來源於這三個tpl文件。
現在我們來打開header.tpl,index,tpl 還有footer.tpl,這里對於web設計師會相對熟悉點
Header.tpl
1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="{$lang_iso}">
3. <head>
4. <base href="{$protocol}{$smarty.server.HTTP_HOST|escape:'htmlall':'UTF-8'}{$base_dir}" />
5. <title>{$meta_title|escape:'htmlall':'UTF-8'}</title>
6. {if isset($meta_description) AND $meta_description}
7. <meta name="description" content="{$meta_description|escape:htmlall:'UTF-8'}" />
8. {/if}
9. {if isset($meta_keywords) AND $meta_keywords}
10. <meta name="keywords" content="{$meta_keywords|escape:htmlall:'UTF-8'}" />
11. {/if}
12. <meta http-equiv="Content-Type" content="application/xhtml+xml; charset=utf-8" />
13. <meta name="generator" content="PrestaShop" />
14. <meta name="robots" content="{if isset($nobots)}no{/if}index,follow" />
15. <link rel="icon" type="image/vnd.microsoft.icon" href="{$img_ps_dir}favicon.ico" />
16. <link rel="shortcut icon" type="image/x-icon" href="{$img_ps_dir}favicon.ico" />
17. {if isset($css_files)}
18. {foreach from=$css_files key=css_uri item=media}
19. <link href="{$css_uri}" rel="stylesheet" type="text/css" media="{$media}" />
20. {/foreach}
21. {/if}
22. <script type="text/javascript" src="{$base_dir}js/tools.js"></script>
23. <script type="text/javascript">
24. var baseDir = '{$base_dir}';
25. var static_token = '{$static_token}';
26. var token = '{$token}';
27. var priceDisplayPrecision = {$priceDisplayPrecision*$currency->decimals};
28. </script>
29. <script type="text/javascript" src="{$base_dir}js/jquery/jquery-1.2.6.pack.js"></script>
30. <script type="text/javascript" src="{$base_dir}js/jquery/jquery.easing.1.3.js"></script>
31. {if isset($js_files)}
32. {foreach from=$js_files item=js_uri}
33. <script type="text/javascript" src="{$js_uri}"></script>
34. {/foreach}
35. {/if}
36. {$HOOK_HEADER}
37. </head>
38.
39. <body {if $page_name}id="{$page_name|escape:'htmlall':'UTF-8'}"{/if}>
40. {if !$content_only}
41. <div id="page">
42.
43. <!-- Header -->
44. <div>
45. <h1 id="logo"><a href="{$base_dir}" title="{$shop_name|escape:'htmlall':'UTF-8'}"><img src="{$img_ps_dir}logo.jpg" alt="{$shop_name|escape:'htmlall':'UTF-8'}" /></a></h1>
46. <div id="header">
47. {$HOOK_TOP}
48. </div>
49. </div>
50.
51. <!-- Left -->
52. <div id="left_column" class="column">
53. {$HOOK_LEFT_COLUMN}
54. </div>
55.
56. <!-- Center -->
57. <div id="center_column">
58. {/if}
Index.tpl
1. {$HOOK_HOME}
Footer.tpl
1. {if !$content_only}
2. </div>
3.
4. <!-- Right -->
5. <div id="right_column" class="column">
6. {$HOOK_RIGHT_COLUMN}
7. </div>
8.
9. <!-- Footer -->
10. <div id="footer">{$HOOK_FOOTER}</div>
11. </div>
12. {/if}
13. </body>
14. </html>
現在我們來看看homepage的源文件:
Index.tpl
1. !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
3. <head>
4. <base href="http://127.0.0.1/prestashop/" />
5. <title>Prestashop demo</title>
6. <meta name="description" content="Shop powered by PrestaShop" />
7. <meta name="keywords" content="shop, prestashop" />
8. <meta http-equiv="Content-Type" content="application/xhtml+xml; charset=utf-8" />
9. <meta name="generator" content="PrestaShop" />
10. <meta name="robots" content="index,follow" />
11. <link rel="icon" type="image/vnd.microsoft.icon" href="/prestashop/img/favicon.ico" />
12. <link rel="shortcut icon" type="image/x-icon" href="/prestashop/img/favicon.ico" />
13. <link href="/prestashop/themes/commotion/css/global.css" rel="stylesheet" type="text/css" media="all" />
14. <script type="text/javascript" src="/prestashop/js/tools.js"></script>
15. <script type="text/javascript">
16. var baseDir = '/prestashop/';
17. var static_token = '';
18. var token = '';
19. var priceDisplayPrecision = 2;
20. </script>
21. <script type="text/javascript" src="/prestashop/js/jquery/jquery-1.2.6.pack.js"></script>
22. <script type="text/javascript" src="/prestashop/js/jquery/jquery.easing.1.3.js"></script>
23. </head>
24. <body id="index">
25. <div id="page">
26.
27. <!-- Header -->
28. <div>
29. <h1 id="logo"><a href="/prestashop/" title="Prestashop demo"><img src="/prestashop/img/logo.jpg" alt="Prestashop demo" /></a></h1>
30. <div id="header">
31.
32. </div>
33. </div>
34.
35. <!-- Left -->
36. <div id="left_column" class="column">
37.
38. </div>
39.
40. <!-- Center -->
41. <div id="center_column">
42. </div>
43.
44. <!-- Right -->
45. <div id="right_column" class="column">
46.
47. </div>
48.
49. <!-- Footer -->
50. <div id="footer">
51. </div>
52. </div>
53. </body>
54. </html>
可能你會注意到了index.tpl 只有一行{$HOOK_HOME}。這里是因為index文件只在homepage上顯示我們所指定的模塊,我們的目錄還有產品頁將會顯示其它的模塊。
當然,你可能也會發現我們每個頁面都有一個不同的body id,方便了我們用css去定義他們單獨的每個頁面,或許你以後還想在body上加上些class,那麼這句是從哪句代碼得來的呢?看看header.tpl,這段代碼就是用來實現它的:
1. <body {if $page_name} id="{$page_name|escape:'htmlall':'UTF-8'}"{/if}> and it is this code that gets the page name. So category.tpl will have the <body id="category">
⑷ php中關於hook用途的問題
PHP 寫插件 其中的HOOK 只是別人想的一個詞語,術語而已
並無實際意義
在WINDOWS編程中 HOOK==鉤子
是一種消息機制的一種
意思就是:蚊子叮了你一口,你的大腦神經接收到了,於是指揮肢體,去趕走還是拍死這個蚊子
這個大腦神經就是HOOK,系統接收用戶操作,而HOOK則監視某一滿足條件
用戶輸入A
,系統接收到A,而HOOK定義接收B,那麼輸入A,則不做操作
當輸入B了,則激活HOOK,進行執行制定代碼
PHP的插件HOOK,比如你添加一個插件,把這個插件信息提前告訴HOOK,然後HOOK去監視用戶
當用戶調用這個插件,HOOK就感知到了
於是就把插件功能實現出來
⑸ PHP 代碼問題
這個類找不到
⑹ php中函數定義的問題
問題1,不好說明白,你可以把它想像為一個函數,只是這個函數放在這個對象裡面看著比較舒服。靜態的方法不用new對象,可以像使用函數一樣用它。
問題2,沒區別,不寫就是public
⑺ PHP中如何實現Hook機制
給你推薦2個方法
類的__call 和__callstatic 。 這2個魔術方法是當調用類的內部方法不存在時執行。__call是實例化類之後調用方法不存在。__callstatic 是調用靜態方法不存在,它裡面的參數包含了方法名和傳遞的參數。這樣就可以利用這2個方法去實現hook機制。根據方法名和參數去找指定位置的文件和方法執行。use_call_func和use_call_func_array 具體看文檔
是反射機制。php已經很早就有反射機制了。利用類的反射機制。去實現hook。其實原理和1方法差不多。但是實現的方法比較高級而已。
⑻ 如何在AKCMS中HOOK(鉤子)執行自己的代碼求解
本功能為二次開發者設計,站長看不懂不影響正常使用,繞行即可。
不需要修改AKCMS的代碼即可實現這樣的功能,不修改AKCMS代碼的好處是保持以後升級的時候不需要把修改過的文件,修改過的代碼merge到新的版本中,始終保持獨立。
AKCMS 2.7以上版本在動態執行時會檢查(/plugins/runtime/)中是否有_before.php結尾的文件,如果有就在頁面打開之前執行他們。頁面打開完畢後檢查(/plugins/runtime/)中是否有_after.php結尾的文件,如果有就執行他們。
例如這個需求:把所有動態執行的每一次訪問的訪問地址都記下日誌以便分析。
拷貝以下代碼:<?php
error_log($_SERVER['REQUEST_URI'].\n, 3, AK_ROOT.'./logs/log.txt');?保存為/plugins/runtime/log_after.php即可。
注意:生成靜態頁之後,直接就是HTML文件的顯示,當然不能執行任何代碼,所以本文所說的功能都是針對AKCMS動態執行時而言。
3.8新增功能:採集功能的hook
hook程序的以函數的形式統一寫在configs/hook.php中,函數命名規則:
1 採集列表頁的hook,命名為hook_spidelist_123(123代表採集規則ID,下同)
2 採集內容頁的hook,命名為hook_spiderurl_123
以數組的形式向hook函數傳入已經採集到的全部數據。舉一個例子:要把採集內容頁(假設內容頁採集規則的ID是1)採集到的title中的字母全部大寫就在/configs/hook.php中增加這樣一個函數:
function hook_spiderurl_1($value) {
$value['title'] = strtoupper($value['title']);
return $value;}保存後就立即生效了,下次採集完ID1的採集規則後,會自動調用這個函數,實現你想要的功能。
3.8.4新增功能:保存內容的hook
hook程序的以函數的形式統一寫在configs/hook.php中,函數命名規則:
1 修改內容正文的hook,命名為hook_saveitemdata_123(123代表所屬模塊ID,下同)
函數會傳入兩個參數,第一個是正文內容,第二個是除正文外其他欄位的一個數組。返回值是處理後的正文內容。
2 修改內容其他欄位的hook,命名為hook_saveitem_123
函數會傳入兩個參數,第一個是除正文外其他欄位的一個數組,第二個是正文內容。返回值是處理後的數組。
⑼ thinphp5 hook怎麼影響控制器
方法一:在入口文件寫入綁定 define('BIND_MODULE','Home'); 直接這樣默認找Home/ 原來url可以去掉home/,直接localhost/test/index訪問
方法二:修改conf.php 找到/application/common/conf/conf.php 這個文件,在原有的代碼裡面加入這句話
'MODULE_ALLOW_LIST' => array ('Home'),
'DEFAULT_MODULE' => 'Home'
意味設置默認控制器為home,同樣可以取消home/
方法三:在入口的index.php文件加入兩句話
$_GET['m'] = 'Home'; // 綁定Home模塊到當前入口文件
$_GET['c'] = 'Index'; // 綁定Index控制器到當前入口文件
效果等同於綁定home模塊,但原來的鏈接必須通過這種方法訪問,這個是很大的弊端,在搜索引擎優化和靜態化網站方法,強烈不推薦使用類型鏈接,/隔開的鏈接才是有利於搜索引擎抓取的。
這個是去掉home的方法,參照這方法,去設置默認的就好了
⑽ 為什麼php webhook 使用介面調用提示無法識git命令
估計和你當前用的 shell 命令行不是同一個 shell 解釋器。
寫 shell 腳本,記住一定要在最開始寫 #!/bin/bash 或者其他的解釋器,比如 csh、tsh。python、perl、php 都可以這么用,這樣你的腳本就制定了一個解釋器來運行。運行時不要用 sh xxx.sh ,而是賦予可運行許可權後 ./xxxx.sh 方式運行。
一般 Linux 下面的 /bin/sh 是一個鏈接,指向一個默認的 shell 解釋器,這個鏈接如果不是你需要的解釋器,那麼腳本運行出現任何問題都可能。如果系統裝了 busybox ,他也會提供一個 sh 解釋器,而且命令的文件名也是 sh ,他和 bash 運行結果也有區別,只是這個 sh 不一定在 /bin 裡面。