關(guān)鍵詞 MVC模式;Struts框架;Web應(yīng)用
中圖分類號(hào) TP391 文獻(xiàn)標(biāo)識(shí)碼 A
1 引言
軟件開(kāi)發(fā)工作中遇到的很多問(wèn)題都可能在以往開(kāi)發(fā)同類軟件的過(guò)程中同樣出現(xiàn)過(guò)并且已經(jīng)被解決,解決問(wèn)題時(shí)所用到的好的方法、技術(shù)經(jīng)過(guò)積累并不斷的歸納、總結(jié)形成一種固定的解決方案、一種模式,以便在日后的系統(tǒng)開(kāi)發(fā)過(guò)程中專門(mén)用來(lái)解決同類問(wèn)題。設(shè)計(jì)模式就是對(duì)以往開(kāi)發(fā)經(jīng)驗(yàn)的總結(jié),它的提出使開(kāi)發(fā)人員可以簡(jiǎn)單、方便的復(fù)用成功的設(shè)計(jì)方案,而不必每次都做重復(fù)的工作。
財(cái)務(wù)系統(tǒng)具有所涉及的業(yè)務(wù)邏輯復(fù)雜、需求靈活,甚至個(gè)別業(yè)務(wù)可能會(huì)在系統(tǒng)使用過(guò)程中發(fā)生變化的特點(diǎn),因此如何組織應(yīng)用程序以使其易于維護(hù)和升級(jí)便成為擺在開(kāi)發(fā)人員面前的首要問(wèn)題。早些時(shí)候的應(yīng)用程序開(kāi)發(fā)是用過(guò)程化語(yǔ)言來(lái)完成的,它們將數(shù)據(jù)庫(kù)查詢語(yǔ)句這樣的數(shù)據(jù)層代碼和HTML這樣的表示層代碼混合在一起,這樣一來(lái)無(wú)論是對(duì)業(yè)務(wù)邏輯的變更還是對(duì)界面顯示的修改都會(huì)涉及到應(yīng)用程序的整體,使程序維護(hù)起來(lái)相當(dāng)困難。
2 Web層的解決方案——MVC模式
MVC模式的提出徹底解決了上述問(wèn)題。MVC是Model(模型)——View(視圖)——Controller(控制器)的縮寫(xiě),它適用于大型可擴(kuò)展的Web應(yīng)用的開(kāi)發(fā),它強(qiáng)制性地將應(yīng)用程序的輸入、處理和輸出分開(kāi),將其劃分為模型、視圖和控制器三個(gè)核心部分,使它們各司其職,各自完成不同的任務(wù),其中任何一部分的修改都不會(huì)影響其它兩部分。
在MVC模式中,模型封裝了應(yīng)用問(wèn)題的核心數(shù)據(jù)、邏輯關(guān)系和業(yè)務(wù)規(guī)則,提供了業(yè)務(wù)邏輯的處理過(guò)程。模型一方面被控制器調(diào)用,完成問(wèn)題處理的操作過(guò)程,另一方面為視圖獲取顯示數(shù)據(jù)提供了訪問(wèn)數(shù)據(jù)的操作。因?yàn)槟P褪桥c數(shù)據(jù)格式無(wú)關(guān)的,因此一個(gè)模型可以為多個(gè)視圖提供數(shù)據(jù),這樣一個(gè)模型一次編寫(xiě)可以被多個(gè)視圖重用,從而避免了代碼的重復(fù)編寫(xiě)。
視圖是MVC模式下用戶看到的并與之交互的界面。視圖從模型處獲得數(shù)據(jù),視圖的更新由控制器控制。視圖不包含任何業(yè)務(wù)邏輯的處理,它只是作為一種輸出數(shù)據(jù)的方式。
MVC模式中,控制器主要起導(dǎo)航的作用,它根據(jù)用戶的輸入調(diào)用相應(yīng)的模型和視圖去完成用戶的請(qǐng)求。控制器本身不輸出任何東西,它接受用戶請(qǐng)求并決定調(diào)用哪個(gè)模型構(gòu)件去處理,以及由哪個(gè)視圖來(lái)顯示模型處理之后返回的數(shù)據(jù)。
MVC的處理過(guò)程是這樣的:對(duì)于每一個(gè)用戶輸入的請(qǐng)求,首先被控制器接收,并決定由哪個(gè)模型來(lái)進(jìn)行處理,然后模型通過(guò)業(yè)務(wù)處理邏輯處理用戶的請(qǐng)求并返回?cái)?shù)據(jù),最后控制器用相應(yīng)的視圖格式化模型返回的數(shù)據(jù),并通過(guò)顯示頁(yè)面呈現(xiàn)給用戶。圖1所示為模型、視圖、控制器這三個(gè)模塊各自的功能以及它們之間的相互關(guān)系:
圖1