網(wǎng)站的軟架構(gòu) |
發(fā)布時(shí)間: 2012/9/16 20:36:47 |
現(xiàn)在的PHP框架有很多選擇,比如:CakePHP,Symfony,Zend Framework等等,至于應(yīng)該使用哪一個(gè)并沒有唯一的答案,要根據(jù)Team里團(tuán)隊(duì)成員對(duì)各個(gè)框架的了解程度而定。很多時(shí)候,即使沒有使用框架,一樣能 寫出好的程序來(lái),比如Flickr據(jù)說(shuō)就是用Pear+Smarty這樣的類庫(kù)寫出來(lái)的,所以,是否用框架,用什么框架,一般不是最重要的,重要的是我們 的編程思想里要有框架的意識(shí)。
邏輯的分層網(wǎng)站規(guī)模到了一定的程度之后,代碼里各種邏輯糾纏在一起,會(huì)給維護(hù)和擴(kuò)展帶來(lái)巨大的障礙,這時(shí)我們的解決方式其實(shí)很簡(jiǎn)單,那就是重構(gòu),將邏輯進(jìn)行分層。通常,自上而下可以分為表現(xiàn)層,應(yīng)用層,領(lǐng)域?qū)樱志脤印?表現(xiàn)層所謂表現(xiàn)層,并不僅僅就指模板,它的范圍要更廣一些,所有和表現(xiàn)相關(guān)的邏輯都應(yīng)該被納入表現(xiàn)層的范疇。比如說(shuō)某處的字體要顯示為紅色,某處的開頭要 空兩格,這些都屬于表現(xiàn)層。很多時(shí)候,我們?nèi)菀追傅腻e(cuò)誤就是把本屬于表現(xiàn)層的邏輯放到了其他層面去完成,這里說(shuō)一個(gè)很常見的例子:我們?cè)诹斜眄?yè)顯示文章標(biāo) 題的時(shí)候,都會(huì)設(shè)定一個(gè)最大字?jǐn)?shù),一旦標(biāo)題長(zhǎng)度超過(guò)了這個(gè)限制,就截?cái),并在后面顯示“..”,這就是最典型的表現(xiàn)層邏輯,但是實(shí)際情況,有很多程序員都 是在非表現(xiàn)層代碼里完成數(shù)據(jù)的獲取和截?cái),然后賦值給表現(xiàn)層模板,這樣的代碼最直接的缺點(diǎn)就是同樣一段數(shù)據(jù),在這個(gè)頁(yè)面我可能想顯示前10個(gè)字,再另一個(gè) 頁(yè)面我可能想顯示前15個(gè)字,而一旦我們?cè)诔绦蚶锕袒诉@個(gè)字?jǐn)?shù),也就喪失了可移植性。正確的做法是應(yīng)該做一個(gè)視圖助手之類的程序來(lái)專門處理此類邏輯,比 如說(shuō):Smarty里的truncate就屬于這樣的視圖助手(不過(guò)它那個(gè)實(shí)現(xiàn)不適合中文)。應(yīng)用層所謂應(yīng)用層,它的主要作用是定義用戶可以做什么,并把操作結(jié)果反饋給表現(xiàn)層。至于如何做,通常不是它的職責(zé)范圍(而是領(lǐng)域?qū)拥穆氊?zé)范圍),它會(huì)通過(guò) 委派把如何做的工作交給領(lǐng)域?qū)尤ヌ幚。在使用MVC架構(gòu)的網(wǎng)站中,我們可以看到類似下面這樣的URL: domain/articles/view/123,其內(nèi)部編碼實(shí)現(xiàn),一般就是一個(gè)Articles控制器類,里面有一個(gè)view方法,這就是一 個(gè)典型的應(yīng)用層操作,因?yàn)樗x了用戶可以做一個(gè)查看的動(dòng)作。在MVC架構(gòu)中,有一個(gè)準(zhǔn)則是這么說(shuō)的:Rich Model Is Good。言外之意,就是Controller要保持“瘦”一些比較好,進(jìn)而說(shuō)明應(yīng)用層要盡量簡(jiǎn)單,不要包括涉及領(lǐng)域內(nèi)容的邏輯。領(lǐng)域?qū)?/span>所謂領(lǐng)域?qū),最直接的解釋就是包含領(lǐng)域邏輯的層。它是一個(gè)軟件的靈魂所在。先來(lái)看看什么叫領(lǐng)域邏輯,簡(jiǎn)單的說(shuō),具有明確的領(lǐng)域概念的邏輯就是領(lǐng)域邏輯,比如我們?cè)贏TM機(jī)上取錢,過(guò)程大致是這樣的:插入銀聯(lián)卡,輸入密碼,輸入取款金額,確定,拿錢,然后ATM吐出一個(gè)交易憑條。在這個(gè)過(guò)程中,銀聯(lián)卡 在ATM機(jī)器里完成錢從帳戶上劃撥的過(guò)程就是一個(gè)領(lǐng)域邏輯,因?yàn)槿″X在銀行中是一個(gè)明確的領(lǐng)域概念,而ATM機(jī)吐出一個(gè)交易憑條則不是領(lǐng)域邏輯,而僅是一 個(gè)應(yīng)用邏輯,因?yàn)橥鲁鼋灰讘{條并不是銀行中一個(gè)明確的領(lǐng)域概念,只是一種技術(shù)手段,對(duì)應(yīng)的,我們?nèi)″X后不吐交易憑條,而發(fā)送一條提醒短信也是可能的,但并 不是一定如此,如果在實(shí)際情況中,我們要求取款后必須吐出交易憑條,也就是說(shuō)吐出交易憑條已經(jīng)和取款緊密結(jié)合,那么你也可以把吐出交易憑條看作是領(lǐng)域邏輯 的一部分,一切都以問(wèn)題的具體情況而定。在Eric那本經(jīng)典的領(lǐng)域驅(qū)動(dòng)設(shè)計(jì)中,把領(lǐng)域?qū)臃譃榱宋宸N基本元素:實(shí)體,值對(duì)象,服務(wù),工廠,倉(cāng)儲(chǔ)。具體可以參 閱書中的介紹。領(lǐng)域?qū)幼畛7傅腻e(cuò)誤就是把本應(yīng)屬于領(lǐng)域?qū)拥倪壿嬓孤兜搅似渌麑哟危热缯f(shuō)在一個(gè)CMS系統(tǒng),對(duì)熱門文章的定義是這樣的:每天被瀏覽的次數(shù)多 于1000次,被評(píng)論的次數(shù)多于100次,這樣的文章就是熱門文章。對(duì)于一個(gè)CMS來(lái)說(shuō),熱門文章這個(gè)詞無(wú)疑是一個(gè)重要的領(lǐng)域概念,那么我們?nèi)绾螌?shí)現(xiàn)這個(gè) 邏輯的設(shè)計(jì)的?你可能會(huì)給出類似下面的代碼:“SELECT ... FROM ... WHERE 瀏覽 > 1000 AND 評(píng)論 > 100”,沒錯(cuò),這是最簡(jiǎn)單的實(shí)現(xiàn)方式,但是這里需要注意的是“每天被瀏覽的次數(shù)多于1000次,被評(píng)論的次數(shù)多于100次”這個(gè)重要的領(lǐng)域邏輯被隱藏到 了SQL語(yǔ)句中,SQL語(yǔ)句顯然不屬于領(lǐng)域?qū)拥姆懂,也就是說(shuō),我們的領(lǐng)域邏輯泄露了。持久層所謂持久層,就是指把我們的領(lǐng)域模型保存到數(shù)據(jù)庫(kù)中。因?yàn)槲覀兊某绦虼a是面向?qū)ο?/a>風(fēng)格的,而數(shù)據(jù)庫(kù)一般是關(guān)系型的數(shù)據(jù)庫(kù),所以我們需要把領(lǐng)域模型 碾平,才能保存到數(shù)據(jù)庫(kù)中,但是在PHP里,直到目前還沒有非常好的ORM出現(xiàn),所以這方面的解決方案不是特別多,參考Martin的企業(yè)應(yīng)用架構(gòu)模式一 書,大致可以使用的方法有行數(shù)據(jù)入口(Row Data Gateway)或者表數(shù)據(jù)入口(Table Data Gateway),或者把領(lǐng)域?qū)雍统志脤雍隙䴙橐蛔兂苫顒?dòng)記錄(Active Record)的方式。億恩小路QQ572931335電話15890397512租用與托管有興趣請(qǐng)聯(lián)系我:億恩-小路1339268817 電話:15890397512 本文出自:億恩科技【www.allwellnessguide.com】 服務(wù)器租用/服務(wù)器托管中國(guó)五強(qiáng)!虛擬主機(jī)域名注冊(cè)頂級(jí)提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM] |