php單一入口模式可謂是現在一種比較流行的大型web應用開發模式,比如當前比較流行的一些php開發框架,zend,thinkphp,qeephp,還有cakephp 等他們都是采用的單一入口模式的。本文將就什麼是單一入口模式,單一入口模式有哪些優點以缺點做一下研究。
什麼是單一入口?
在解釋什麼是單一入口之前,先說說與之對應的多入口。多入口即通過訪問不同的 php 文件運行對應的功能。比如剛開始學習 php 的時候,我們做一個項目通常都會如下這樣做:
index.php - 網站首頁
list.php?page=5 - 內容列表頁
info.php?id=12 - 內容詳細頁
login.php - 用戶登錄頁
對於這個項目來說,這其實就是一個多入口。
那麼單一入口的應用程序就是說用一個文件處理所有的HTTP請求,例如不管是內容列表頁,用戶登錄頁還是內容詳細頁,都是通過從浏覽器訪問 index.php 文件來進行處理的,這裡這個 index.php 文件就是這個應用程序的單一入口。
php 是如何實現單一入口的呢?
很簡單,一般單一入口程序都是在訪問index.php時附帶一個特定的參數。例如:index.php?action=list 就可以定義為訪問內容列表頁,而 index.php?action=info 則可以定義為訪問內容詳細頁等,具體實現代碼如下:
$action=$_GET['action']==''?'index':$_GET['action'];//從url中取出action參數,如果沒有提供action參數,就設置一個默認的'index'作為參數 include('files/'.$action.'.php');//根據$action參數調用不同的代碼文件,從而滿足單一入口實現對應的不同的功能
以上這個就實現了一個最簡單的單一入口模式程序,當然真正的單一入口模式會比這個要復雜很多。但只要懂得如何合理組織各個功能的處理代碼並遵循一定的步驟,也可以輕松的解決掉這個難題,下面就一個後台的例子來做一下說明:
比如我們現在要做一個新聞管理的後台。那麼首先,對於應用程序的功能要做出一個合理的分解。例如後台的新聞欄目可能包含“添加新聞”、“編輯新聞”、“刪除新聞”等多個功能。這時我們就可以將這一組邏輯上關聯的功能組合到一個功能模塊中,稱為“新聞管理”模塊。
按照上面的方法整理完應用程序的功能,我們就會得到多個功能模塊,而每個模塊又是由多個功能組成(實際上,即便不是單一入口應用程序,功能的整理也是必須的步驟)。
整理完功能後,我們就需要確定如何存放各個功能的代碼。這裡我推薦兩種方式:
1、每個功能模塊一個子目錄,目錄裡的每一個文件就是一個功能的實現代碼。
這種方式的好處是每個功能的代碼都互相隔離,非常便於多人協作。缺點是每個功能之間共享代碼和數據不那麼方便。例如新聞管理模塊中的所有功能都需要一個“取出新聞欄目記錄”的功能,那麼采用這種多個獨立文件的組織方式,“取出新聞欄目記錄”就只能寫在另一個文件中,然後由需要該功能的文件include 進去。
2、每個模塊一個文件,模塊中的每個功能寫成一個函數或者一個類方法。
好處不用多說了,非常便於共享代碼和數據。缺點就是如果幾個人同時改,容易發生沖突。不過借助版本控制軟件和差異比較合並工具,沖突還是很容易解決的。
單一入口應用程序對應多入口有哪些優勢呢?
單一入口應用程序的所有http請求都是通過index.php接收並轉發到功能代碼中去的,所以在index.php裡面就能完成許多實際工作(所有頁面都需要做的且都一樣的工作)。比如進行集中的安全性檢查,訪問統計等等,如果不是單一入口,那麼開發者就必須記得在每一個文件的開始加上安全性檢查代碼,當然,你也許會說,多入口的安全性檢查可以寫到另一個文件中,然後include一下就可以了。但實際針對一個相對較大型一點的應用項目,在幾十個文件中保持頭部的幾個include都一致可不是一件讓人省心的事。
與安全性檢查類似。在入口裡,我們還可以對url參數和post進行必要的檢查和特殊字符過濾、記錄日志、訪問統計等等各種可以集中處理的任務。這樣就可以看出,由於這些工作都被集中到了index.php來完成,可以減輕我們維護其他功能代碼的難度。
單一入口應用程序的缺點?
任何事情都有兩面性,單一入口應用程序也不例外。由於所有http請求都是訪問 index.php ,所以程序的 url 看起來不那麼美觀,特別是對搜索引擎來說不太友好。比如下面這個 url:
http://www.phpernote.com/index.php?controller=posts&action=index
我們知道這種URl不太方便記憶,而且搜索引擎不認它是一個正常的 URL,當然是相比下面這種 URl 來說的:
http://www.phpernote.com/index.php/posts/index/
不過這個也不是什麼大問題,可以采用url重寫、PATHINFO等方式就可以輕松解決這個問題。
OK,單一入口模式就寫這麼多了,當然要想深刻理解單一模式,最好的辦法還是自己嘗試著用單一入口模式寫一個小應用出來深刻體會一下。