這篇文章的出發(fā)點是我對插件機制的理解,及其在PHP中的實現(xiàn)。此方案僅是插件機制在PHP中的實現(xiàn)方案之一,寫下來和大家分享,歡迎大家一起討論。
插件,亦即Plug-in,是指一類特定的功能模塊(通常由第三方開發(fā)者實現(xiàn)),它的特點是:當你需要它的時候激活它,不需要它的時候禁用/刪除它;且無論是激活還是禁用都不影響系統(tǒng)核心模塊的運行,也就是說插件是一種非侵入式的模塊化設計,實現(xiàn)了核心程序與插件程序的松散耦合。一個典型的例子就是Wordpress中眾多的第三方插件,比如Akimet插件用于對用戶的評論進行Spam過濾。
一個健壯的插件機制,我認為必須具備以下特點:
- 插件的動態(tài)監(jiān)聽和加載(Lookup)
- 插件的動態(tài)觸發(fā)
- 以上兩點的實現(xiàn)均不影響核心程序的運行
要在程序中實現(xiàn)插件,我們首先應該想到的就是定義不同的鉤子(Hooks);“鉤子”是一個很形象的邏輯概念,你可以認為它是系統(tǒng)預留的插件觸發(fā)條件。它的邏輯原理如下:當系統(tǒng)執(zhí)行到某個鉤子時,會判斷這個鉤子的條件是否滿足;如果滿足,會轉而先去調用鉤子所制定的功能,然后返回繼續(xù)執(zhí)行余下的程序;如果不滿足,跳過即可。這有點像匯編中的“中斷保護”邏輯。
某些鉤子可能是系統(tǒng)事先就設計好的,比如之前我舉的關于評論Spam過濾的鉤子,通常它已經(jīng)由核心系統(tǒng)開發(fā)人員設計進了評論的處理邏輯中;另外一類鉤子則可能是由用戶自行定制的(由第三方開發(fā)人員制定),通常存在于表現(xiàn)層,比如一個普通的PHP表單顯示頁面中。
可能你感覺上面的話比較無聊,讓人昏昏欲睡;但是要看懂下面我寫的代碼,理解以上的原理是必不可少的。
下面進行PHP中插件機制的核心實現(xiàn),整個機制核心分為三大塊:
- 一個插件經(jīng)理類:這是核心之核心。它是一個應用程序全局Global對象。它主要有三個職責:
- 負責監(jiān)聽已經(jīng)注冊了的所有插件,并實例化這些插件對象。
- 負責注冊所有插件。
- 當鉤子條件滿足時,觸發(fā)對應的對象方法。
- 插件的功能實現(xiàn):這大多由第三方開發(fā)人員完成,但需要遵循一定的規(guī)則,這個規(guī)則是插件機制所規(guī)定的,因插件機制的不同而不同,下面的顯示代碼你會看到這個規(guī)則。
- 插件的觸發(fā):也就是鉤子的觸發(fā)條件。具體來說這是一小段代碼,放置在你需要插件實現(xiàn)的地方,用于觸發(fā)這個鉤子。
出處:藍色理想
責任編輯:bluehearts
上一頁 下一頁 PHP中插件機制的一種實現(xiàn)方案 [2]
◎進入論壇網(wǎng)絡編程版塊參加討論
|