在 JavaEE 項目的開發(fā)中宏粤,不管是對底層的數(shù)據(jù)庫操作過程脚翘,還是業(yè)務(wù)層的處理過程,還是控制層的處理過程绍哎,都不可避免會遇到各種可預(yù)知的来农、不可預(yù)知的異常需要處理。每個過程都單獨處理異常崇堰,系統(tǒng)的代碼耦合度高沃于,工作量大且不好統(tǒng)一,維護的工作量也很大海诲。
SpringMvc 對于異常處理這塊提供了支持繁莹,通過 SpringMvc 提供的全局異常處理機制,能夠?qū)⑺蓄愋偷漠惓L幚韽母鱾€處理過程解耦出來特幔,這樣既保證了相關(guān)處理過程的功能較單一咨演,也實現(xiàn)了異常信息的統(tǒng)一處理和維護。
SpringMVC全局異常處理的三種方式
使用 Spring MVC 提供的簡單異常處理器 SimpleMappingExceptionResolver蚯斯;
實現(xiàn) Spring 的異常處理接口 HandlerExceptionResolver 自定義自己的異常處理器薄风;
使用 @ExceptionHandler 注解實現(xiàn)異常處理;
案例實操
全局異常處理方式一
配置 SimpleMappingExceptionResolver 對象
<beanclass="org.springframework.web.servlet.handler.SimpleMappingException Resolver">
<propertyname="defaultErrorView"value="error"></property>
<propertyname="exceptionAttribute"value="ex"></property>
<propertyname="exceptionMappings">
<props>
<propkey="com.xxx.exception.BusinessException">error1</prop>
<propkey="com.xxx.exception.ParamsException">error2</prop>
</props>
</property>
</bean>
使用 SimpleMappingExceptionResolver 進(jìn)行異常處理拍嵌,具有集成簡單遭赂、有良好的擴展性、對已有代碼沒有入侵性等優(yōu)點横辆,但該方法僅能獲取到異常信息撇他,若在出現(xiàn)異常時,對需要獲取除異常以外的數(shù)據(jù)的情況不適用龄糊。
全局異常處理方式二
實現(xiàn) HandlerExceptionResolver 接口?
@Component
publicclassGlobalExceptionimplementsHandlerExceptionResolver{
@Override
publicModelAndViewresolveException(HttpServletRequestrequest,
HttpServletResponseresponse,Objecthandler,Exceptionex) {
Map<String,Object>map=newHashMap<String,Object>();
map.put("ex",ex);
ModelAndViewmv=null;
if(exinstanceofParamsException){
? ? returnnewModelAndView("error_param",map);
? ? ? ? ?? }
if(exinstanceofBusinessException){
? ? returnnewModelAndView("error_business",map);
? ? ? ? ?? }
returnnewModelAndView("error",map);
?? }
}
使用實現(xiàn) HandlerExceptionResolver 接口的異常處理器進(jìn)行異常處理逆粹,具有集成簡單、有良好的擴展性炫惩、對已有代碼沒有入侵性等優(yōu)點僻弹,同時,在異常處理時能獲取導(dǎo)致出現(xiàn)異常的對象他嚷,有利于提供更詳細(xì)的異常處理信息蹋绽。
全局異常處理方式三
頁面處理器繼承 BaseController
publicclassBaseController{
@ExceptionHandler
publicStringexc(HttpServletRequestrequest,HttpServletResponse
response,Exceptionex){
request.setAttribute("ex",ex);
if(exinstanceofParamsException){
return"error_param";
? ? ?? }
if(exinstanceofBusinessException){
return"error_business";
? ? ?? }
return"error";
?? }
}
使用 @ExceptionHandler 注解實現(xiàn)異常處理芭毙,具有集成簡單、有擴展性好(只需要將要異常處理的 Controller 類繼承于 BaseController 即可)卸耘、不需要附加 Spring 配置等優(yōu)點退敦,但該方法對已有代碼存在入侵性(需要修改已有代碼,使相關(guān)類繼承于 BaseController)蚣抗,在異常處理時不能獲取除異常以外的數(shù)據(jù)侈百。
擴展~未捕獲異常的處理
對于 Unchecked Exception 而言,由于代碼不強制捕獲翰铡,往往被忽略钝域,如果運行期產(chǎn)生了 Unchecked Exception,而代碼中又沒有進(jìn)行相應(yīng)的捕獲和處理锭魔,則我們可能不得不面對尷尬的 404例证、500……等服務(wù)器內(nèi)部錯誤提示頁面。我們需要一個全面而有效的異常處理機制迷捧。目前大多數(shù)服務(wù)器也都支持在 Web.xml 中通過 <error-page>(Websphere/Weblogic) 或者 <error-code>(Tomcat) 節(jié)點配置特定異常情況的顯示頁面织咧。修改 web.xml 文件,增加以下內(nèi)容:
<!-- 出錯頁面定義 -->
<error-page>
? ? <exception-type>java.lang.Throwable</exception-type>
? ? <location>/500.jsp</location>
</error-page>
<error-page>
? ? <error-code>500</error-code>
? ? <location>/500.jsp</location>
</error-page>
<error-page>
? ? <error-code>404</error-code>
? ? <location>/404.jsp</location>
</error-page>
各位需要詳細(xì)資料的+小姐姐V:lezijie003(備注678漠秋,不備注不加哦笙蒙!)