基於MVC模式的Struts框架在財務系統中的應用

基於MVC模式的Struts框架在財務系統中的應用

作者:郭建春 於書舉 來源:ahcit http://www.csai.cn 2005年12月31日

  摘要 對於項目開發人員來說,要加快系統的開發速度、提高系統的可維護性和可擴展性,首要的任務是劃分好系統的層次結構,合理地設計表示邏輯、業務處理邏輯和數 據邏輯。MVC模式就是一個很好的將表示、控制和業務處理相分離的解決方案,本文則主要介紹了Struts框架下的財務系統的設計和實現。

  關鍵詞 MVC模式;Struts框架;Web應用

  中圖分類號 TP391 文獻標識碼 A

  1 引言

  軟 件開發工作中遇到的很多問題都可能在以往開發同類軟件的過程中同樣出現過並且已經被解決,解決問題時所用到的好的方法、技術經過積累並不斷的歸納、總結形 成一種固定的解決方案、一種模式,以便在日後的系統開發過程中專門用來解決同類問題。設計模式就是對以往開發經驗的總結,它的提出使開發人員可以簡單、方 便的複用成功的設計方案,而不必每次都做重複的工作。

  財 務系統具有所涉及的業務邏輯複雜、需求靈活,甚至個別業務可能會在系統使用過程中發生變化的特點,因此如何組織應用程序以使其易於維護和升級便成爲擺在開 發人員面前的首要問題。早些時候的應用程序開發是用過程化語言來完成的,它們將數據庫查詢語句這樣的數據層代碼和HTML這樣的表示層代碼混合在一起,這 樣一來無論是對業務邏輯的變更還是對界面顯示的修改都會涉及到應用程序的整體,使程序維護起來相當困難。

  2 Web層的解決方案——MVC模式

  MVC 模式的提出徹底解決了上述問題。MVC是Model(模型)——View(視圖)——Controller(控制器)的縮寫,它適用於大型可擴展的Web 應用的開發,它強制性地將應用程序的輸入、處理和輸出分開,將其劃分爲模型、視圖和控制器三個核心部分,使它們各司其職,各自完成不同的任務,其中任何一 部分的修改都不會影響其它兩部分。

  在MVC 模式中,模型封裝了應用問題的核心數據、邏輯關係和業務規則,提供了業務邏輯的處理過程。模型一方面被控制器調用,完成問題處理的操作過程,另一方面爲視 圖獲取顯示數據提供了訪問數據的操作。因爲模型是與數據格式無關的,因此一個模型可以爲多個視圖提供數據,這樣一個模型一次編寫可以被多個視圖重用,從而 避免了代碼的重複編寫。

  視圖是MVC模式下用戶看到的並與之交互的界面。視圖從模型處獲得數據,視圖的更新由控制器控制。視圖不包含任何業務邏輯的處理,它只是作爲一種輸出數據的方式。

  MVC模式中,控制器主要起導航的作用,它根據用戶的輸入調用相應的模型和視圖去完成用戶的請求。控制器本身不輸出任何東西,它接受用戶請求並決定調用哪個模型構件去處理,以及由哪個視圖來顯示模型處理之後返回的數據。

  MVC 的處理過程是這樣的:對於每一個用戶輸入的請求,首先被控制器接收,並決定由哪個模型來進行處理,然後模型通過業務處理邏輯處理用戶的請求並返回數據,最 後控制器用相應的視圖格式化模型返回的數據,並通過顯示頁面呈現給用戶。圖1所示爲模型、視圖、控制器這三個模塊各自的功能以及它們之間的相互關係:

圖1

  3 Struts是實現MVC模式的框架  

  設 計模式是軟件開發經驗的總結,它是一個概念,是一個邏輯實體,而框架可以看成是基於某一特定平臺的一種或幾種設計模式的物理實現。設計模式比框架更抽象, 設計模式只有其實例才能表示爲代碼,而框架本身可以用代碼表示,框架是一套設計詳細的類,類與類之間功能各異,又彼此聯繫,相輔相成,形成了對某一類問題 的可重用的、易擴展的解決方案

  Struts 是實現MVC模式的通用框架,它由四個主要部分組成,模型、視圖、控制器和XML文件。模型通常由Java Bean或EJB組件實現,負責處理業務邏輯;視圖包括一組JSP文件,這些文件主要由JSP標籤或客戶化標籤構成,它簡化了JSP頁面的編碼工作;在 Struts框架中控制器主要包括Action Servlet類和Action類,Action Servlet是Struts的核心部件,它接受用戶的Http請求,根據配置信息將請求轉發給適當的Action對象,Action類負責調用模型的方 法,並幫助控制應用程序的流程;Struts包括Web.xml和Struts—config.xml兩個配置文件,其中Web.xml是Web應用的發 布描述文件,Struts—config.xml是與Struts相關的特殊信息配置的描述文件。

  4 Struts框架下的財務系統的設計與實現

  項目由財務系統、物流系統和客戶管理系統三個部分構成,由於財務的結算業務與採購、出入庫和銷售等物流環節都存在着一定的聯繫,因此,財務系統功能的實現以及維護的方便與否對於整個項目的成敗起着致關重要的作用。

  財 務系統主要包括與結算相關的業務處理,如供貨商結算、客戶結算、返款處理、各種帳簿的查詢、科目表的維護等等。下面以客戶結算爲例說明Struts框架下 系統的設計與實現。用戶選擇客戶結算子菜單後進入客戶結算頁面,在該頁面上需填入客戶名稱、銷售單編碼、費用的支付方式以及詳細的收款信息。其中客戶名稱 和銷售單編碼支持模糊查詢功能;支付方式包括現金、銀行、預收款三種方式,可點選輸入;詳細的收款信息包括業務員姓名或編碼、總的結算金額、登錄帳簿。以 上信息均填寫完畢後,可點擊提交,若填寫的信息符合結算條件,則經業務處理邏輯處理後,系統向用戶顯示結算單頁面,若提交不成功,則顯示錯誤信息。Web 組件之間信息的轉發關係如圖2所示

圖2

  CtmBForm作爲ActionForm Bean可以在視圖和控制器之間傳遞HTML表單,其屬性與表單中的字段是一一對應的,CtmBForm的Validate()方法可以完成與表單的數據格式和語法相關的有效性檢查,如銷售單編碼、結算金額不能爲空等。

  Struts 框架的核心控制器組件ActionServlet的doGet()或doPost()方法在收到用戶請求後都會調用其process()方法處理請求。首 先選擇能夠處理當前請求的子應用模塊,並在request範圍內寫入配置信息和消息資源;之後完成一些預處理請求操作,在預處理請求操作的尾部創建並保存 CtmBAction實例,並調用CtmBAction實例的execute()方法,該方法再調用相應模型進行實際的業務邏輯處理,完成用戶的請求;最 後根據execute()方法返回的結果執行請求轉發或重定向。在系統中模型由EJB組件實現,系統多層結構的設計如圖3所示:

圖3

   CtmBEJB作爲一種JNDI資源運行在EJB容器中,在多層結構中CtmBEJBDelegateImpl業務代理實現類無法創建CtmBEJB組 件,而是通過查找名爲“ejb/CtmBEJB”的JNDI資源獲得該資源的引用。IctmB接口的作用是削弱客戶程序與模型的關係,客戶程序通過該接口 來訪問EJB組件的業務方法。

  CtmBAction對EJB組件進行調用的時序圖如圖4所示:

圖4

  在 多層結構中,業務對象BO主要封裝了一些實體,如客戶CustomerBO、銷售單SalesSlipBO、結算單BalancingSlipBO、應收 款帳AccountsReceivableBO、預收款帳PreReceivingBO、現金帳CashAccountBO和銀行帳 BankAccountBO等等。圖5所示爲上述七個業務對象之間的關聯關係,以及部分業務對象的屬性和方法:


圖5

  數 據訪問對象(Data Access Object,簡稱DAO)是實現持久化框架的一種設計模式,它的引入可以削弱業務處理邏輯和數據庫訪問之間的聯繫,它一方面可以將對業務對象BO的處理 轉化爲對數據庫的操作,另一方面也可以把查詢數據庫的結果映射爲業務對象BO。DAO提供了對關係數據庫操作的接口,如創建數據庫,定義表、索引,對錶進 行增、刪、改、查詢等操作。系統選用了OJB軟件,它是一種採用DAO設計模式實現的持久化框架。

  5 結束語

  Struts 爲Web應用程序的開發提供了框架結構,JSP頁面中不包含任何業務邏輯,控制器組件ActionServlet可使用Struts框架所提供的,開發人 員只需將大部分精力集中到實際業務邏輯的處理,這樣有利於快速有效的開發出Web應用程序。Struts框架下用戶顯示、控制邏輯和業務處理邏輯相分離, 若業務需求發生變化則主要修改用於處理業務邏輯的EJB或JavaBean組件,因此便於系統的維護和升級。總之,Struts框架適用於可擴展的大型 Web應用的開發。

  參考文獻
  1 James Turner Kevin Bedell,Struts Kick Start, Copyright ? 2003 by Sams Publishing
  2 孫衛琴.精通Struts:基於MVC的Java Web設計與開發.電子工業出版社,2004年8月
  3 Gamma,Erich,Design patterns :elements of reusable object—oriented software,China Machine Press,2002/01/01
  4 張麗君,齊建卓,吳宏波.基於MVC模式的Struts框架在Web系統開發中的應用.內蒙古大學學報,2005年1月第36卷第1期
  5 柯喆,張忠能.Struts在開發B/S結構系統中的應用.計算機工程,2004年12月第30卷

  <script src="http://51cmm.csai.cn/rightlist.asp" language="JavaScript" type="text/javascript"></script> <script src="http://www.csai.cn/ad/showad.asp?adno=066" language="javascript" type="text/javascript"></script> <script src="http://51cmm.csai.cn/channel_left_right.asp" language="javascript" type="text/javascript"></script> <script src="http://www.csai.cn/ad/showad.asp?adno=069" language="javascript" type="text/javascript"></script> <script src="http://bbs.csai.cn/bbs_right.asp" language="javascript" type="text/javascript"></script> <script src="http://www.csai.cn/ad/showad.asp?adno=070" language="javascript" type="text/javascript"></script> <script src="http://818.csai.cn/818_right.asp" language="javascript" type="text/javascript"></script> <script src="http://www.csai.cn/ad/showad.asp?adno=067" language="javascript" type="text/javascript"></script> <script src="http://blog.csai.cn/blog_right.asp" language="javascript" type="text/javascript"></script> 希賽網廣告招商
頻道最新文章
·寧波首家軟件企業通過CM
·企業聘用人才的基本標準
·五步求解PERT圖
·性格——影響管理者職業生
·Vlan中的Trunk技
·施工項目進度控制
·施工項目進度比較與計劃調
·雙絞線測試重要參數詳解
·開源測試工具介紹
希賽會員俱樂部小廣告
社區最新帖子排行
·考過高分的網絡工程師~進~
·【求助】讀軟件工程的大三m
·05年11月所有級別答案集
·2006年4月三級 答案討
·軟考圖書購買指南,不讀可不
·CMM經典:<軟件過程管理
·找人:邢紹志,劉秋林,劉明
·一個有創意的薪酬管理方法
·有很多人說考微軟認證的人是
·[討論]當你測試的時候開發
CMM評選投票小廣告
希賽休閒吧新帖排行
·漂亮美眉在森林公園男廁門口
·股民的夫妻生活(爆笑成人限
·女大學生口述:處女難,做學
·是誰趁黑偷偷摸了局長的老婆
·領工資VS女人例假(經典)
·戲說大學男生失戀完全手冊
·能夠殺死女人的20句話
·19歲德國女孩一天睡64個
·史上最流行爆笑全集--女生
·這個很牛,絕對經典!(爆笑
遠程教育平臺小形象廣告
希賽IT博客人氣榜
·ejb corba com
·創建模式之--Single
·轉載-跨數據庫文獻檢索統一
·如何求一個數組的大小?
·《組件生存週期管理設計解密
·Free Door1.0介
·《組件生存週期管理設計解密
·26個英文字母所代表的涵義
·.net中連接數據庫的問題
發佈了28 篇原創文章 · 獲贊 1 · 訪問量 9萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章