基於MVC的Struts在財務系統中的應用

來源:互聯網
上載者:User
  摘要 對於項目開發人員來說,要加快系統的開發速度、提高系統的可維護性和可擴充性,首要的任務是劃分好系統的階層,合理地設計表示邏輯、業務處理邏輯和資料邏輯。MVC模式就是一個很好的將表示、控制和業務處理相分離的解決方案,本文則主要介紹了Struts架構下的財務系統的設計和實現。
  關鍵詞   MVC模式;Struts架構;Web應用
  中圖分類號 TP391      文獻標識碼  A
   引言
  軟體開發工作中遇到的很多問題都可能在以往開發同類軟體的過程中同樣出現過並且已經被解決,解決問題時所用到的好的方法、技術經過積累並不斷的歸納、總結形成一種固定的解決方案、一種模式,以便在日後的系統開發過程中專門用來解決同類問題。設計模式就是對以往開發經驗的總結,它的提出使開發人員可以簡單、方便的複用成功的設計方案,而不必每次都做重複的工作。
  財務系統具有所涉及的商務邏輯複雜、需求靈活,甚至個別業務可能會在系統使用過程中發生變化的特點,因此如何組織應用程式以使其易於維護和升級便成為擺在開發人員面前的首要問題。早些時候的應用程式開發是用過程化語言來完成的,它們將資料庫查詢語句這樣的資料層代碼和HTML這樣的展示層代碼混合在一起,這樣一來無論是對商務邏輯的變更還是對介面顯示的修改都會涉及到應用程式的整體,使程式維護起來相當困難。
   Web層的解決方案——MVC模式
  MVC模式的提出徹底解決了上述問題。MVC是Model(模型)——View(視圖)——Controller(控制器)的縮寫,它適用於大型可擴充的Web應用的開發,它強制性地將應用程式的輸入、處理和輸出分開,將其劃分為模型、視圖和控制器三個核心部分,使它們各司其職,各自完成不同的任務,其中任何一部分的修改都不會影響其它兩部分。
  在MVC模式中,模型封裝了應用問題的核心資料、邏輯關係和商務規則,提供了商務邏輯的處理過程。模型一方面被控制器調用,完成問題處理的操作過程,另一方面為視圖擷取顯示資料提供了訪問資料的操作。因為模型是與資料格式無關的,因此一個模型可以為多個視圖提供資料,這樣一個模型一次編寫可以被多個視圖重用,從而避免了代碼的重複編寫。
  視圖是MVC模式下使用者看到的並與之互動的介面。視圖從模型處獲得資料,視圖的更新由控制器控制。視圖不包含任何商務邏輯的處理,它只是作為一種輸出資料的方式。
  MVC模式中,控制器主要起導航的作用,它根據使用者的輸入調用相應的模型和視圖去完成使用者的請求。控制器本身不輸出任何東西,它接受使用者請求並決定調用哪個模型構件去處理,以及由哪個視圖來顯示模型處理之後返回的資料。
  MVC的處理過程是這樣的:對於每一個使用者輸入的請求,首先被控制器接收,並決定由哪個模型來進行處理,然後模型通過業務處理邏輯處理使用者的請求並返回資料,最後控制器用相應的視圖格式化模型返回的資料,並通過顯示頁面呈現給使用者。圖1所示為模型、視圖、控制器這三個模組各自的功能以及它們之間的相互關係:

圖1
   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相關的特殊資訊配置的描述檔案。
   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 Objects(Data Access Object,簡稱DAO)是實現持久化架構的一種設計模式,它的引入可以削弱業務處理邏輯和資料庫訪問之間的聯絡,它一方面可以將對業務對象BO的處理轉化為對資料庫的操作,另一方面也可以把查詢資料庫的結果映射為業務對象BO。DAO提供了對關聯式資料庫操作的介面,如建立資料庫,定義表、索引,對錶進行增、刪、改、查詢等操作。系統選用了OJB軟體,它是一種採用DAO設計模式實現的持久化架構。
   結束語
  Struts為Web應用程式的開發提供了架構結構,JSP頁面中不包含任何商務邏輯,控制器組件ActionServlet可使用Struts架構所提供的,開發人員只需將大部分精力集中到實際商務邏輯的處理,這樣有利於快速有效開發出Web應用程式。Struts架構下使用者顯示、控制邏輯和業務處理邏輯相分離,若業務需求發生變化則主要修改用於處理商務邏輯的EJB或JavaBean組件,因此便於系統的維護和升級。總之,Struts架構適用於可擴充的大型Web應用的開發。

相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。