2013年最流行的php框架盤點(diǎn)
PHP框架的發(fā)展背景
毫無(wú)疑問(wèn),Web框架技術(shù)在近幾年已經(jīng)得到了突飛猛進(jìn)的發(fā)展和普及,在過(guò)去幾年里,框架技術(shù)的普遍經(jīng)歷了比較大的完善過(guò)程,很大一部分可以歸因于Ruby on Rails,以及在其他編程語(yǔ)言中流露出的MVC框架思想。
如果你是一個(gè)PHP忍者,而不是一個(gè)鐵桿的Ruby追隨者,你也許會(huì)驚奇市面上已經(jīng)有這么多的框架,哪一個(gè)才是適合你的。當(dāng)然回答和個(gè)問(wèn)題取決于的諸多因素,今天我們將會(huì)回顧一下這個(gè)典型的問(wèn)題,如何為你的下一個(gè)應(yīng)用系統(tǒng)選擇適合你的PHP框架。
同時(shí)我們也來(lái)看一下比較流行的PHP框架,比較一下他們的區(qū)別,這樣可以幫你自己做出明智的選擇,找到最適合你項(xiàng)目的框架。
明確你的需求
在你決定為你的項(xiàng)目選擇一個(gè)框架之前,你當(dāng)先理解需要,需求和了解一些開(kāi)發(fā)團(tuán)隊(duì)幕后的工作,我們總結(jié)出了如下幾個(gè)問(wèn)題,在開(kāi)始下一步之前你可以試著問(wèn)問(wèn)自己。
你的應(yīng)用程序主要集中于解決哪些問(wèn)題?
你的應(yīng)用可以是一個(gè)電子商務(wù)平臺(tái),一個(gè)社交網(wǎng)站,消息共享平臺(tái)或者活動(dòng)目錄,舉例來(lái)說(shuō),如果你正在構(gòu)建一個(gè)電子商務(wù)網(wǎng)站,你也許更希望選用一些具有 用于處理信用卡和交易會(huì)話的成熟的擴(kuò)展函數(shù)庫(kù)的框架。另一方面,如果是一個(gè)輕量級(jí)的消息平臺(tái)(比如說(shuō)微博類系統(tǒng)),則你也許更應(yīng)該注重快速的擴(kuò)展和跨服務(wù) 器跨數(shù)據(jù)的支撐訪問(wèn)能力,為了實(shí)現(xiàn)負(fù)載均衡和快速連接訪問(wèn)。
你的主機(jī)運(yùn)行環(huán)境將是什么?
有些特殊的框架會(huì)需要使用到一些非默認(rèn)的其它PHP擴(kuò)展或者軟件安裝在服務(wù)器上,比如,有些框架的數(shù)據(jù)抽象層必須要求通過(guò)PDO來(lái)實(shí)現(xiàn)訪問(wèn),而非直 接調(diào)用更底層的MySQL或MySQLi,或者有些類似wiki類的程序的圖像壓縮和處理功能往往需要使用到ImageMagick 或 Graphiviz 這些外部程序。而這些擴(kuò)展也許并不會(huì)被所有的共享主機(jī)環(huán)境(虛擬主機(jī))支持,此外即便是一個(gè)輕量級(jí)的小型框架,而且自我集成了所有所需的函數(shù)庫(kù)并且也具有 良好的可移植性和適應(yīng)性,這樣的框架應(yīng)用在處理數(shù)據(jù)密集型的操作或者大型數(shù)據(jù)處理的系統(tǒng)時(shí),性能又會(huì)成為它的主要瓶頸。
我曾經(jīng)有一次印象深刻的性能優(yōu)化經(jīng)驗(yàn),當(dāng)我們?yōu)?http://i.openbiz.cn 這個(gè)網(wǎng)站進(jìn)行性能優(yōu)化分析的時(shí)候,我的同事總是抱怨為什么加載一個(gè)頁(yè)面居然需要10秒那么久,而我根本看不到這個(gè)現(xiàn)象,后來(lái)發(fā)現(xiàn)應(yīng)為我開(kāi)發(fā)時(shí)候主要用的語(yǔ) 言是英語(yǔ),而他QA所使用的語(yǔ)言版本是中文,我們實(shí)現(xiàn)代碼內(nèi)是依賴Zend_Locale這個(gè)擴(kuò)展來(lái)實(shí)現(xiàn)一些常用字符的國(guó)際化,例如$=>¥的現(xiàn)實(shí)判別和貨幣、數(shù)字顯示方式等,而Zend在這方面卻是做的很全面支持了上百個(gè)國(guó)家的信息,而通過(guò)xhprof分析后發(fā)現(xiàn),因?yàn)閦end在為每一個(gè)字符串做現(xiàn)實(shí)處理的時(shí)候都通過(guò)SimpleXML接口 進(jìn)行了大量的數(shù)據(jù)查詢,這個(gè)活兒居然開(kāi)銷了9秒,最后我們還是換了一種更輕量的方式來(lái)解決這個(gè)問(wèn)題,畢竟我們要面對(duì)的不是實(shí)現(xiàn)全球兩百多個(gè)國(guó)家的顯示支持,目前也就中國(guó)、美國(guó)、香港、臺(tái)灣5個(gè)主要地區(qū)而已。
你的開(kāi)發(fā)人員或團(tuán)隊(duì)的優(yōu)勢(shì)和劣勢(shì)在于什么?
如果你是個(gè)項(xiàng)目經(jīng)理,一個(gè)重要的事情是了解清楚你的具體開(kāi)發(fā)人員他們的能力和弱勢(shì),因?yàn)樗麄兪钦娴膼烆^干活兒人,所以也許你可以選擇一些更加面向開(kāi) 發(fā)人員友好的容易上手的框架。當(dāng)然這個(gè)問(wèn)題的也許并不是影響決定是否采用一個(gè)框架的決定性因素(不斷地要求自己和團(tuán)隊(duì)學(xué)習(xí)新的技術(shù)總是好的),但著絕對(duì)是 一個(gè)會(huì)影響到你的時(shí)間表、預(yù)算和安全等多方面因素的重要考量條件。
如何在“高耦合性” 還是 “低耦合性” 的框架中做出選擇?
如果從框架產(chǎn)品自身的耦合性來(lái)將目前主流的php框架產(chǎn)品分為高耦合性和低耦合性兩類。低耦合性的框架看起來(lái)更像是一個(gè)豐富的函數(shù)庫(kù)和邏輯封裝的抽 象層,甚至有些好的框架自身就是PHP的一個(gè)高級(jí)擴(kuò)展組件,比如PDO,它絕對(duì)算得上是一個(gè)數(shù)據(jù)訪問(wèn)的框架也是抽象層。還有一些其他值得一提的低耦合性框 架,比如Zend Framework,CakePHP,以及國(guó)內(nèi)開(kāi)發(fā)的ThinkPHP都屬于這個(gè)范疇。 如果你將接手的項(xiàng)目歷史問(wèn)題比較多,并且對(duì)UI的自定義比較高,你恐怕需要一個(gè)低耦合性的框架來(lái)滿足你靈活的需求。
另一方面是一些高耦合性框架的代表,比如一些由CRM衍生而來(lái)框架類似Drupal,Joomla,還有直接就是為了高耦合性而開(kāi)發(fā)的 Openbiz Cubi 框架,國(guó)內(nèi)小范圍流行的框架還有 普元 等。這些框架的最優(yōu)秀的特點(diǎn)是可以讓你完全只集中于實(shí)現(xiàn)你的核心業(yè)務(wù)邏輯,你甚至不用去管如何實(shí)現(xiàn)UI和用戶會(huì)話管理這些基礎(chǔ)特性,你只需要把你的代碼和 它們提供的接口規(guī)范進(jìn)行“連接”就可以了。 如果你負(fù)責(zé)的項(xiàng)目是一個(gè)新的項(xiàng)目,你肯定不希望把大部分的時(shí)間都花在實(shí)現(xiàn)基礎(chǔ)業(yè)務(wù)邏輯上,比如可能是為客戶公司開(kāi)發(fā)一套“停車場(chǎng)管理系統(tǒng)”,還是選擇類似 Openbiz Cubi 這樣的框架,在其之上直接去實(shí)現(xiàn)你的業(yè)務(wù)邏輯是最對(duì)得起你的時(shí)間預(yù)算和投資回報(bào)率的。