異常是當(dāng)JVM(JAVA虛擬機(jī))在執(zhí)行應(yīng)用程序的某個(gè)方法的時(shí)候遇到的非正常現(xiàn)象,JVM就會生成一個(gè)異常對象,拋給客戶以便客戶進(jìn)行異常處理.Struts框架的異常處理機(jī)制建立在java異常處理的基礎(chǔ)之上.在研究Struts異常處理之前,先回顧一下java異常處理原理,理解java虛擬機(jī)JVM的異常處理過程有助于應(yīng)用設(shè)計(jì)正確的異常處理方法.處理異常需要JVM付出不小的開銷,所以用于必須慎重使用.
JAVA異常是在java程序運(yùn)行的時(shí)候遇到非正常的情況而創(chuàng)建的對象,它封裝了異常信息,java異常的根類為java.lang.Throwable,整個(gè)類有兩個(gè)直接子類java.lang.Error和java.lang.Exception.Error是程序本身無法恢復(fù)的嚴(yán)重錯(cuò)誤.Exception則表示可以被程序捕獲并處理的異常錯(cuò)誤.JVM用方法調(diào)用棧來跟蹤每個(gè)線程中一系列的方法調(diào)用過程,該棧保存了每個(gè)調(diào)用方法的本地信息.對于獨(dú)立的JAVA程序,可以一直到該程序的main方法.當(dāng)一個(gè)新方法被調(diào)用的時(shí)候,JVM把描述該方法的棧結(jié)構(gòu)置入棧頂,位于棧頂?shù)姆椒檎_執(zhí)行的方法.當(dāng)一個(gè)JAVA方法正常執(zhí)行完畢,JVM回從調(diào)用棧中彈處該方法的棧結(jié)構(gòu),然后繼續(xù)處理前一個(gè)方法.如果java方法在執(zhí)行代碼的過程中拋出異常,JVM必須找到能捕獲異常的catch塊代碼.它首先查看當(dāng)前方法是否賊這樣的catch代碼塊,如果存在就執(zhí)行該catch代碼塊,否則JVM回調(diào)用棧中彈處該方法的棧結(jié)構(gòu),繼續(xù)到前一個(gè)方法中查找合適的catch代碼塊.最后如果JVM向上追到了main()方法,也就是一直把異常拋給了main()方法,仍然沒有找到該異常處理的代碼塊,該線程就會異常終止,如果該線程是主線程,應(yīng)用程序也隨之終止,此時(shí)JVM將把異常直接拋給用戶,在用戶終端上會看到原始的異常信息.回顧完了JAVA的異常處理機(jī)制,就要開始研究Struts的異常處理了.
Struts框架在視圖層和控制層提供了對異常處理的支持.Struts的控制器負(fù)責(zé)捕獲各種異常,包括控制器運(yùn)行中本身拋出的異常,以及調(diào)用模型的業(yè)務(wù)方法的異常.當(dāng)異常被控制器捕獲的時(shí)候,在異常處理代碼塊中,創(chuàng)建描述異常信息的ActionMessage對象把它保存在ActionMessages或者它的子類ActionErrors對象中,然后把它保存在特定的范圍內(nèi),比如request或session.接下來在視圖層<html:error>標(biāo)簽檢索特定范圍的ActionMessages對象,把本地化錯(cuò)誤消息輸出到頁面上.這種異常處理機(jī)制可以避免用戶看到原始的java異常信息.可以更友好的把錯(cuò)誤信息展示給用戶.
Struts框架處理異常是以JVM的異常處理機(jī)制為基礎(chǔ)的,盡管它提供了強(qiáng)大的通用錯(cuò)誤處理機(jī)制,但是不能保證捕獲到所有的異常或者錯(cuò)誤.當(dāng)錯(cuò)誤發(fā)生的時(shí)候,如果Struts不能處理這種異常或者錯(cuò)誤,就把錯(cuò)誤拋給JavaWeb容器.容器先查看是否在Web應(yīng)用發(fā)布描述文件中配置了<error-page>元素,如果存在該元素就返回元素的子元素<location>指定的錯(cuò)誤頁面,否則就會把錯(cuò)誤直接拋給用戶.下面簡單介紹一Struts幾個(gè)重要的類的異常處理機(jī)制,如果想了解這幾個(gè)類的更深的異常機(jī)制,建議查看Struts源代碼.
1) ActionServlet類的peocess()方法不捕獲任何異常,僅僅聲明向上層調(diào)用方法拋出異常.
2) RequestProcessor類是Struts框架處理異常的核心組件.
3) ExceptionHandler類是默認(rèn)的異常處理類,它的execute()方法負(fù)責(zé)處理異常.
根據(jù)打造技術(shù)Blog,尋求JAVA精髓! Servlet規(guī)范,當(dāng)容器捕獲到異常的時(shí)候,將查看是否在Web.xml中配置了相
應(yīng)的<error-page>元素,如果存在,就會返回其<location>子元素指定的錯(cuò)誤頁面.舉個(gè)簡單明了的例子如下:
<error-page>
<error-code>500</error>
<location>/error.jsp</location>
</error-page>
<error-page>
<exception-type>javax.servlet.ServletException</error>
<location>/error.jsp</location>
</error-page>
Struts框架也允許以配置的方式來處理異常,配置方法可以避免在Action類中通過硬編碼來處理異常,提高應(yīng)用的靈活性,可重用性和可維護(hù)性.對于Action類的execute()方法拋出的異常會先查找異常處理元素<exception>,如果是被嵌套在<global-exception>元素中就表示是全局異常處理元素,對所有的Action都適用.如果是嵌套在<action>元素中,就表示局部的異常處理元素,僅對當(dāng)前的Action適用.闡述一下<exception>元素的屬性:
1) type:指定待處理的異常類
2) handler:指定異常處理類.默認(rèn)是ExceptionHandler.如果自己要定義必須繼承它
3) path:指定轉(zhuǎn)發(fā)路徑
4) key:指定錯(cuò)誤消息key.根據(jù)這個(gè)key到ResourceBundle中尋找匹配的消息文本
5) bundle:指定ResourceBundle,如果沒設(shè)置將使用哦么人的ResourceBundle
6) scope:指定ActionMessages對象的存放范圍,默認(rèn)request,也可以設(shè)置session
Struts框架提供了強(qiáng)大的異常處理功能,Struts控制器負(fù)責(zé)捕獲異常,并把異常包裝與
ResourceBundle綁定的ActionMessages對象,在視圖層<html:error>標(biāo)簽?zāi)軌蝻@示出來,主要可以通過配置的方式和編程的方式實(shí)現(xiàn),這里不推薦用編程的方法,可以增強(qiáng)程序的靈活性,可重用性,可維護(hù)性. (網(wǎng)友們的支持,是我繼續(xù)寫技術(shù)文章的動(dòng)力!)
posted on 2005-10-29 14:02
我心依舊 閱讀(7665)
評論(10) 編輯 收藏