




全文預(yù)覽已結(jié)束
下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
什么是單一入口應(yīng)用程序?在解釋什么是單一入口應(yīng)用程序之前,我們先來看看傳統(tǒng)的 web 應(yīng)用程序。news.php 顯示新聞列表news_edit.php 顯示新聞編輯頁面這兩個(gè)頁面不但分別實(shí)現(xiàn)了兩個(gè)功能,還成為了應(yīng)用程序的兩個(gè)入口。那什么是入口???打個(gè)比方,大家上 WC,都是男生進(jìn)一個(gè)門,女生進(jìn)一個(gè)門。這兩個(gè)門就是 WC 的兩個(gè)入口。呵呵,上面的例子應(yīng)該很好理解吧。那稍微變換一下,單一入口的概念就很容易理解了?,F(xiàn)在我們是進(jìn)一個(gè)公共 WC,不管男女都是從最外面的入口進(jìn)入,交了錢以后才分別進(jìn)兩個(gè)門。那最外面的入口就是這個(gè) WC 的單一入口。所以單一入口的應(yīng)用程序?qū)嶋H上就是說用一個(gè)文件處理所有的 HTTP 請求。例如不管是新聞列表功能還是新聞編輯功能,都是從瀏覽器訪問 index.php 文件。這個(gè) index.php 文件就是這個(gè)應(yīng)用程序的單一入口。index.php 如何知道用戶是要使用哪一個(gè)功能呢?很簡單,我們訪問 index.php 時(shí)跟上一個(gè)特定的參數(shù)就行了。例如 index.php?action=news 就是顯示新聞列表,而 index.php?action=news_edit 就是新聞編輯。而在 index.php 里面,僅用兩行代碼就可以實(shí)現(xiàn)這種效果。上面的代碼中,第一行是從 url 中取出 action 參數(shù)。如果沒有提供 action 參數(shù),就設(shè)置一個(gè)默認(rèn)的 index 作為參數(shù)。第二行代碼就是根據(jù) $action 參數(shù)調(diào)用不同的代碼文件,從而實(shí)現(xiàn)單一入口對應(yīng)不同功能的效果。單一入口應(yīng)用程序的入口文件很復(fù)雜?有些朋友可能以為單一入口程序的 index.php 會像面條一樣復(fù)雜,其實(shí)是誤解。例如我現(xiàn)在的應(yīng)用程序入口文件只有下面幾行:足夠簡單了吧?當(dāng)然了,在 index.php 里面寫上一長串 switch case 絕對是拙劣的實(shí)現(xiàn)方式。但這純粹是開發(fā)者自己的設(shè)計(jì)和實(shí)現(xiàn)問題,而不是單一入口應(yīng)用程序這種設(shè)計(jì)思想的問題。補(bǔ)充說明:這里提到 switch case 并不是說用了 switch 就代表“落后”、“土氣”等。只是說在 index.php 這個(gè)入口程序里面寫上一堆 switch case 不利于程序的修改和維護(hù),所以是一種不好的用法。單一入口應(yīng)用程序的設(shè)計(jì)思想當(dāng)web服務(wù)器(apache或者iis)收到一個(gè)http請求時(shí),會解析該請求,確定要訪問哪一個(gè)文件。例如 /news.php 的解析結(jié)果就是要求web服務(wù)器解析 news.php 文件,并返回結(jié)果給瀏覽器?,F(xiàn)在看看單一入口應(yīng)用程序的 index.php 文件,就會發(fā)現(xiàn) index.php 實(shí)際上根據(jù) url 參數(shù)進(jìn)行了第二次解析。完成這個(gè)解析的程序一般稱為 Dispatcher(中文的準(zhǔn)確翻譯我也不知道),大概意思就是將不同的請求轉(zhuǎn)發(fā)到不同的處理程序進(jìn)行處理。在單一入口應(yīng)用程序中,index.php 和 web服務(wù)器一起構(gòu)成了一個(gè) Dispatcher,根據(jù) http 請求和 url 參數(shù)來確定請求的處理程序。了解了 Dispatcher 的概念后,我們可以發(fā)現(xiàn)前面提到的兩行代碼實(shí)際上就是一個(gè)最簡單的 Dispatcher 實(shí)現(xiàn):誠然,對于一個(gè)安全、健壯的應(yīng)用程序,Dispatcher 肯定不是上面那么簡單。在調(diào)用實(shí)際代碼前,還會加上各種判斷、安全性檢查等。例如判斷 url 指定的功能是否可以訪問以及 url 中包含了無效的參數(shù)??吹竭@里,朋友們肯定會說:單一入口程序就多了就這樣一個(gè) dispatcher ,和我直接做成 news.php、news_edit.php 等單個(gè)文件相比有什么好處???單一入口應(yīng)用程序的優(yōu)勢單一入口應(yīng)用程序的所有http請求都是通過 index.php 接收并轉(zhuǎn)發(fā)到功能代碼去的,所以我們在 index.php 里面就能完成許多實(shí)際工作。這里我只拿安全性檢查為例詳細(xì)說明一下:由于所有的 http 請求都由 index.php 接收,所以可以進(jìn)行集中的安全性檢查。如果不是單一入口,那么開發(fā)者就必須記得在每一個(gè)文件的開始加上安全性檢查代碼(當(dāng)然,安全性檢查代碼可以寫到另一個(gè)文件中,只需要include進(jìn)來就可以了)。但我想大家都是懶人,也許記性也不好,難免有忘記的時(shí)候。因此要記得在每一個(gè)文件前面都加上必要的include可不是件容易做到的事情。與安全性檢查類似。在入口里,我們還可以對url參數(shù)和post進(jìn)行必要的檢查和特殊字符過濾、記錄日志、訪問統(tǒng)計(jì)等等各種可以集中處理的任務(wù)?!斑祝氵@么多功能,不是會把 index.php 搞得很復(fù)雜嗎?”“不會的。只需要把各種功能寫到單獨(dú)的文件,然后在index.php里面include進(jìn)來就可以了!”可以看出,由于這些工作都被集中到了 index.php 來完成,可以減輕我們維護(hù)其他功能代碼的難度。例如在10個(gè)文件中保持頭部的幾個(gè)include都一致可不是件讓人愉快的事情。單一入口應(yīng)用程序的缺點(diǎn)任何事情都有兩面性,單一入口應(yīng)用程序也不例外。由于所有 http 請求都是針對 index.php,所以應(yīng)用程序的 url 看起來確實(shí)不那么美觀。特別是對搜索引擎來說很不友好。要解決這個(gè)問題,可以采用 url 重寫、PATHINFO 等方式。但我個(gè)人更推薦在前臺頁面不使用單一入口方式,而是保持多個(gè)文件入口?;蛘邇烧呋煊?。例如新聞列表采用單獨(dú)的 news.php 顯示,而用戶注冊、發(fā)表信息等則采用單一入口。因?yàn)閷τ诰W(wǎng)站擁有者來說,新聞列表、新聞顯示頁面才是需要搜索引擎關(guān)注的高價(jià)值目標(biāo),而用戶注冊頁面等交互性功能則根本沒有收錄的價(jià)值。有朋友提到單一入口的應(yīng)用程序會有很長一串參數(shù),那么我們分析一下下面這個(gè) url:index.php?url=news&news_id=123&page=2&sort=title如果改為直接訪問 news.php,也只不過省掉了 url=news 這一個(gè)參數(shù)而已。所以認(rèn)為單一入口的應(yīng)用程序 url 太復(fù)雜是沒有道理的。如何組織單一入口應(yīng)用程序的功能代碼?單一入口應(yīng)用程序最大的挑戰(zhàn)來自于如何合理組織各個(gè)功能的處理代碼。但只要遵循一定的步驟,也可以輕松的解決掉這個(gè)難題。首先,對于應(yīng)用程序的功能要做出一個(gè)合理的分解。例如后臺的新聞欄目可能包含“添加新聞”、“編輯新聞”、“刪除新聞”等多個(gè)功能。這時(shí)我們就可以將這一組邏輯上關(guān)聯(lián)的功能組合到一個(gè)功能模塊中,稱為“新聞管理”模塊。按照上面的方法整理完應(yīng)用程序的功能,我們就會得到多個(gè)功能模塊,而每個(gè)模塊又是由多個(gè)功能組成。(實(shí)際上,即便不是單一入口應(yīng)用程序,功能的整理也是必須的步驟。)整理完功能后,我們就需要確定如何存放各個(gè)功能的代碼。這里我推薦兩種方式:1、每個(gè)功能模塊一個(gè)子目錄,目錄里的每一個(gè)文件就是一個(gè)功能的實(shí)現(xiàn)代碼。這種方式的好處是每個(gè)功能的代碼都互相隔離,非常便于多人協(xié)作。缺點(diǎn)是每個(gè)功能之間共享代碼和數(shù)據(jù)不那么方便。例如新聞管理模塊中的所有功能都需要一個(gè)“取出新聞欄目記錄”的功能,那么采用這種多個(gè)獨(dú)立文件的組織方式,“取出新聞欄目記錄”就只能寫在另一個(gè)文件中,然后由需要該功能的文件include進(jìn)去。2、每個(gè)模塊一個(gè)文件,模塊中的每個(gè)功能寫成一個(gè)函數(shù)或者一個(gè)類方法。好處不用多說了,非常便于共享代碼和數(shù)據(jù)。缺點(diǎn)就是如果幾個(gè)人同時(shí)改,容易發(fā)生沖突。不過借助版本控制軟件和差異比較合并工具,沖突還是很容易解決的。好了,我們的功能代碼都確定存放方式了。那么如何調(diào)用呢?index.php 如何調(diào)用功能代碼?調(diào)用首先就是要設(shè)計(jì)一個(gè)規(guī)則,然后讓 index.php 根據(jù)這個(gè)規(guī)則來搜索和調(diào)用功能代碼。就我自己來說,我總是使用 $_GETurl 來指定要調(diào)用的功能模塊,而 $_GETaction 來指定該模塊的特定功能。因此我的應(yīng)用程序會使用如下的 url 地址:index.php?url=news&action=edit覺得兩個(gè)參數(shù)太多了?那可以使用 index.php?func=news.edit 這樣的 url。只需要將 news.edit 拆開為 news 和 edit 就行了?!昂俸?,那我故意搞一個(gè) index.php?url=news&action=xxx,看你的應(yīng)用程序還能運(yùn)行?”很顯然,這樣的 url 只會使得 index.php 無法找到需要的功能代碼,最后報(bào)告錯誤。但是這和你在瀏覽器中訪問 newsxxx.php 這個(gè)并不存在的文件有什么本質(zhì)區(qū)別呢?相反,我還可以讓 index.php 在發(fā)現(xiàn)找不到需要的功能代碼時(shí)顯示一個(gè)漂亮的出錯頁面,并提供一個(gè)返回網(wǎng)站首頁的連接。在實(shí)際開發(fā)中,我傾向于將一些基本服務(wù)從應(yīng)用程序中抽取出來,形成一個(gè)應(yīng)用程序框架。這個(gè)框架通常會包含一個(gè) Dispatcher、基本的數(shù)據(jù)庫訪問服務(wù)、模版引擎、常用的輔助功能等。由于有了一個(gè)框架,所以我可以更加讓 Dispatcher 更加靈活。例如可以對某些功能模塊應(yīng)用權(quán)限檢查,而另一些則不檢查。進(jìn)一步了解單一入口應(yīng)用程序要深刻理解一個(gè)事物,自己嘗試一下是最好的辦法。你可以選擇自己實(shí)現(xiàn)一個(gè) Dispatcher 以及相應(yīng)的各種規(guī)則,或者選擇一個(gè)現(xiàn)有的應(yīng)用程序框架。但更好的方式還是首先嘗試一下現(xiàn)有的框架,然后再自己嘗試實(shí)現(xiàn)一個(gè)類似的。這樣可以在最短的時(shí)間內(nèi)獲得最多的收獲。目前絕大多數(shù) php 應(yīng)用程序框架都是單一入口的,并采用了 MVC 模式(很遺憾,由于 MVC 實(shí)在太復(fù)雜,并且和單一入口應(yīng)用程序也沒有必然聯(lián)系,所以我就不贅述了。感興趣的朋友可以 google 一下相關(guān)資料)。我個(gè)人推薦下面的框架:FleaPHP/嗯,我在做廣告。因?yàn)檫@個(gè)框架是我做的。但我相信這個(gè)框架將是一個(gè)非常容易上手(就算不是最容易的)框架。全中文的代碼注釋、簡單的結(jié)構(gòu)、精簡的代碼都是 FleaPHP 框
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 藥學(xué)專業(yè)的倫理與法律考量試題及答案
- 護(hù)理職業(yè)生涯執(zhí)業(yè)阻礙研究試題及答案
- 血管健康考試題及答案
- 新高考情景化試題及答案
- 護(hù)理服務(wù)質(zhì)量評價(jià)相關(guān)知識試題及答案
- 環(huán)境改善與母豬護(hù)理試題及答案
- 電廠審計(jì)面試題及答案
- 激光照射工藝的參數(shù)調(diào)整試題及答案
- 藥劑風(fēng)險(xiǎn)管理策略試題及答案
- 衛(wèi)生管理公共健康考題及答案
- 刮痧技術(shù)操作流程圖
- ISO9001 2015版質(zhì)量管理體系標(biāo)準(zhǔn)
- 山西省博物院講解詞(全)
- 部編版《語文》三年級下冊全冊教案及反思
- 自考07887平面設(shè)計(jì)(12-19)真題試卷
- 嘉賓禮簿婚禮禮金記賬本模板
- 高大模板工程驗(yàn)收表
- (中職)Photoshop基礎(chǔ)實(shí)用教程全冊教案2022-2023學(xué)年
- 酒店旅館防偷拍攝像頭排查指引
- GB/T 21655.2-2019紡織品吸濕速干性的評定第2部分:動態(tài)水分傳遞法
- 電力工程標(biāo)準(zhǔn)規(guī)范清單(2023年3月份)
評論
0/150
提交評論