最近已經(jīng)有了很多相關(guān)的介紹,jsp正在成為一種卓越的java技術(shù),可用于創(chuàng)建動態(tài)Web應用程序。Java程序員之所以喜愛JSP有數(shù)不清的理由。有些人喜歡它為交互式頁面帶來的“一次編寫,處處使用”的方式;還有些人欣賞它是因為它容易學習,并且使他們可以把Java作為一種服務(wù)器端腳本語言來使用。但更多的還都是因為一個共同原因――使用JSP的最大好處是它能幫助你有效地把表達與內(nèi)容分離開。在本文中,我對下面的問題作了深入探討,那就是,如何使用JSP Model 2體系結(jié)構(gòu)獲得最佳的表達-內(nèi)容分離效果。這個模型也可以被看作是通用MVC設(shè)計模式在服務(wù)器端的一個實現(xiàn)。請注意,在閱讀本文之前,你需要熟悉基本的JSP和servlet編程,因為文中將不會涉及到任何語法規(guī)則問題。
不同的體系 早期的JSP規(guī)范提出了兩種用JSP技術(shù)建立應用程序的方式。這兩種方式在術(shù)語中分別稱作JSP Model 1 和JSP Model 2,它們的本質(zhì)區(qū)別在于處理批量請求的位置不同。在Model 1體系中,如圖1所示,jsp頁面獨自響應請求并將處理結(jié)果返回客戶。這里仍然存在表達與內(nèi)容的分離,因為所以的數(shù)據(jù)存取都是由bean來完成的。盡管Model 1體系十分適合簡單應用的需要,它卻不能滿足復雜的大型應用程序的實現(xiàn)。不加選擇地隨意運用Model 1,會導致JSP頁內(nèi)被嵌入大量的腳本片段或Java代碼,特別是當需要處理的請求量很大時,情況更為嚴重。盡管這對于Java程序員來說可能不是什么大問題,但如果JSP頁面是由網(wǎng)頁設(shè)計人員開發(fā)并維護的――通常這是開發(fā)大型項目的規(guī)范――這就確實是個問題了。從根本上講,將導致角色定義不清和職責分配不明,給項目管理帶來不必要的麻煩。
Model 2體系結(jié)構(gòu),如圖2所示,是一種把JSP與servlets聯(lián)合使用來實現(xiàn)動態(tài)內(nèi)容服務(wù)的方法。它吸取了兩種技術(shù)各自的突出優(yōu)點,用JSP生成表達層的內(nèi)容,讓servlets完成深層次的處理任務(wù)。在這里,servlets充當控制者的角色,負責管理對請求的處理,創(chuàng)建JSP頁需要使用的bean和對象,同時根據(jù)用戶的動作決定把那個JSP頁傳給請求者。特別要注意,在JSP頁內(nèi)沒有處理邏輯;它僅負責檢索原先由servlets創(chuàng)建的對象或beans,從servlet中提取動態(tài)內(nèi)容插入靜態(tài)模板。在我看來,這是一種有代表性的方法,它清晰地分離了表達和內(nèi)容,明確了角色的定義以及開發(fā)者與網(wǎng)頁設(shè)計者的分工。事實上,項目越復雜,使用Model 2體系結(jié)構(gòu)的好處就越大。