成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

真實項目實踐:快速定位 Spring MVC異常實戰(附源碼下載)

開發 后端
Spring MVC處理異常有3種方式: (1)使用@ExceptionHandler注解實現異常處理; (2)使用Spring MVC提供的簡單異常處理器SimpleMappingExceptionResolver; (3)實現Spring的異常處理接口HandlerExceptionResolver 自定義自己的異常處理器。

一、使用@ExceptionHandler進行處理

 

1.創建異常基類,使用@ExceptionHandler聲明異常處理

BusinessException和SystemException為自定義異常類,代碼如下:

  1. package com.twosnail.exception;  
  2.    
  3. import javax.servlet.http.HttpServletRequest;  
  4. import org.springframework.stereotype.Controller;  
  5. import org.springframework.web.bind.annotation.ExceptionHandler;  
  6.    
  7. @Controller 
  8. public class BasicExController {  
  9.     /**  
  10.      * 基于@ExceptionHandler異常處理基類  
  11.      * @return  
  12.      */ 
  13.     @ExceptionHandler 
  14.     public String exception( HttpServletRequest request , Exception ex ) {  
  15.            
  16.     // 根據不同錯誤轉向不同頁面    
  17.         if( ex instanceof BusinessException ) {  
  18.             return "business-error";    
  19.         }else if( ex instanceof SystemException ) {   
  20.             return "system-error";  
  21.         } else {  
  22.             return "error";    
  23.         }  
  24.     }  

2、使所有需要異常處理的Controller都繼承該類,如下所示:

  1. public class DemoController extends BasicExController {} 

 

然而,Dao層、Service層、Controller層拋出的異常(BusinessException、SystemException和其它異常)都能準確顯示定義的異常處理頁面,達到了統一異常處理的目標。

總結:使用@ExceptionHandler注解實現異常處理,具有集成簡單、有擴展性好(只需要將要異常處理的Controller類繼承于BasicExController即可)、不需要附加Spring配置等優點,但該方法對已有代碼存在入侵性(需要修改已有代碼,使繼承于BasicExController),在異常處理時不能獲取除異常以外的數據。

 

二、SimpleMappingExceptionResolver簡單異常處理器

SimpleMappingExceptionResolver有兩種配置方式,可以按自己需求而定,配置代碼如下:

 

1、第一種,在Spring的配置文件中,增加以下內容:

在這里,可以設置跳轉相應頁面。

  1. <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">  
  2.     <!-- 定義默認的異常處理頁面,當該異常類型的注冊時使用 -->  
  3.     <property name="defaultErrorView" value="error"></property>  
  4.     <!-- 定義異常處理頁面用來獲取異常信息的變量名,默認名為exception -->  
  5.     <property name="exceptionAttribute" value="ex"></property>  
  6.     <!-- 定義需要特殊處理的異常,用類名或完全路徑名作為key,異常也頁名作為值 -->  
  7.     <property name="exceptionMappings">  
  8.         <props>  
  9.             <prop key="com.twosnail.exception.BusinessException">business-error</prop>  
  10.             <prop key="com.twosnail.exception.SystemException">system-error</prop>  
  11.         </props>  
  12.     </property>  
  13.    
  14.     <!-- 相關狀態碼對應的錯誤頁面 -->  
  15.     <property name="statusCodes">  
  16.         <props>  
  17.             <prop key="errors/500">500</prop>  
  18.             <prop key="errors/404">404</prop>  
  19.         </props>  
  20.     </property>  
  21.     <!-- 設置日志輸出級別,不定義則默認不輸出警告等錯誤日志信息 -->  
  22.     <property name="warnLogCategory" value="WARN" />  
  23.     <!-- 默認HTTP狀態碼 -->  
  24.     <property name="defaultStatusCode" value="500" />  
  25. </bean> 

2、第二種,通過自定義java類,繼承SimpleMappingExceptionResolver

然后在Spring的配置。代碼如下:

  1. <bean id="exceptionResolver" class="com.twosnail.exception.MyselfSimpleMappingExceptionResolver">  
  2.     <property name="exceptionMappings">  
  3.         <props>  
  4.             <prop key="com.twosnail.exception.SystemException">error/500</prop>  
  5.             <prop key="com.twosnail.exception.BusinessException">error/errorpage</prop>  
  6.             <prop key="java.lang.exception">error/500</prop>  
  7.         </props>  
  8.     </property>  
  9. </bean> 

java類代碼如下,在這里可以處理相應邏輯,如下,分別處理了jsp頁面和json數據:

  1. package com.twosnail.exception;  
  2.    
  3. import java.io.IOException;  
  4. import java.io.PrintWriter;  
  5. import javax.servlet.http.HttpServletRequest;  
  6. import javax.servlet.http.HttpServletResponse;  
  7. import org.springframework.web.servlet.ModelAndView;  
  8. import org.springframework.web.servlet.handler.SimpleMappingExceptionResolver;  
  9.    
  10. public class MyselfSimpleMappingExceptionResolver extends SimpleMappingExceptionResolver {  
  11.    
  12.     @Override 
  13.     protected ModelAndView doResolveException(HttpServletRequest request,  
  14.             HttpServletResponse response, Object handler, Exception ex) {  
  15.         // Expose ModelAndView for chosen error view.  
  16.         String viewName = determineViewName(ex, request);  
  17.         if (viewName != null) {// JSP格式返回  
  18.             if (!(request.getHeader("accept").indexOf("application/json") > -1 || (request  
  19.                     .getHeader("X-Requested-With") != null && request  
  20.                     .getHeader("X-Requested-With").indexOf("XMLHttpRequest") > -1))) {  
  21.                 // 如果不是異步請求  
  22.                 // Apply HTTP status code for error views, if specified.  
  23.                 // Only apply it if we're processing a top-level request.  
  24.                 Integer statusCode = determineStatusCode(request, viewName);  
  25.                 if (statusCode != null) {  
  26.                     applyStatusCodeIfPossible(request, response, statusCode);  
  27.                 }  
  28.                 return getModelAndView(viewName, ex, request);  
  29.             } else {// JSON格式返回  
  30.                 try {  
  31.                     PrintWriter writer = response.getWriter();  
  32.                     writer.write(ex.getMessage());  
  33.                     writer.flush();  
  34.                 } catch (IOException e) {  
  35.                     e.printStackTrace();  
  36.                 }  
  37.                 return null;  
  38.    
  39.             }  
  40.         } else {  
  41.             return null;  
  42.         }  
  43.     }  

總結:使用SimpleMappingExceptionResolver進行異常處理,具有集成簡單、有良好的擴展性、對已有代碼沒有入侵性等優點,但方法1僅能獲取到異常信息,若在出現異常時,對需要獲取除異常以外的數據的情況不適用。

 

三、HandlerExceptionResolver自定義異常

 

1.在Spring的配置文件中,增加以下內容:

  1. <bean id="exceptionHandler" class="com.twosnail.exception.MyExceptionHandler"/> 

2.添加自定義的MyExceptionHandler類,代碼如下:

在這里,單獨打印出了異常路徑,便于在日志中查看,在對SystemException異常進行了特殊處理:

  1. package com.twosnail.exception;  
  2.    
  3. import java.util.Map;  
  4.    
  5. import javax.servlet.http.HttpServletRequest;  
  6. import javax.servlet.http.HttpServletResponse;  
  7. import org.springframework.web.servlet.HandlerExceptionResolver;  
  8. import org.springframework.web.servlet.ModelAndView;  
  9. import org.springframework.web.servlet.View;  
  10. import org.springframework.web.servlet.view.RedirectView;  
  11.    
  12. public class MyExceptionHandler implements HandlerExceptionResolver {  
  13.    
  14.     public ModelAndView resolveException( HttpServletRequest request, HttpServletResponse response,   
  15.             Object handler, Exception exception ) {  
  16.            
  17.         System.out.println( "【拋出異常】--異常路徑為:" +   
  18.             request.getServletPath() + "\n【異常信息】--" +  exception.getMessage() ) ;  
  19.         //如果不是拋出的action業務異常則不處理  
  20.         if( !( exception instanceof SystemException ) ) {  
  21.             return null;  
  22.         }  
  23.            
  24.         final SystemException actionE = (SystemException) exception;         
  25.         ModelAndView model = null;  
  26.         if( actionE.getForwardType() == SystemException.FORWARD ) {  
  27.                 //進入頁面渲染  
  28.                 model = new ModelAndView( actionE.getModelPath(), actionE.getAttributes());  
  29.         } else if( actionE.getForwardType() == SystemException.REDIRECT ) {  
  30.                 model = new ModelAndView( new RedirectView( actionE.getModelPath(), true));  
  31.         } else {  
  32.             //直接返回頁面內容  
  33.             model = new ModelAndView( new View() {  
  34.                 @Override 
  35.                 public void render(Map<String, ?> arg0, HttpServletRequest arg1,  
  36.                         HttpServletResponse arg2) throws Exception {  
  37.                        
  38.                     arg2.setContentType( "text/html" );  
  39.                     arg2.setCharacterEncoding( actionE.getEncode() );  
  40.                     if( actionE.getResponseBody() != null ) {  
  41.                         arg2.getWriter().print( actionE.getResponseBody() );  
  42.                     }  
  43.                 }  
  44.                    
  45.                 @Override 
  46.                 public String getContentType() {  
  47.                     return "text/html; charset=utf-8";  
  48.                 }  
  49.             } );  
  50.         }  
  51.            
  52.         return model;  
  53.     }  

總結:從上面的集成過程可知,使用實現HandlerExceptionResolver接口的異常處理器進行異常處理,具有集成簡單、有良好的擴展性、對已有代碼沒有入侵性等優點。在異常處理時能獲取導致出現異常的對象,有利于提供更詳細的異常處理信息。而SimpleMappingExceptionResolver就是HandlerExceptionResolver的默認實現類。

四、項目截圖

代碼地址:twosnail源碼地址

參考資料:使用Spring MVC統一異常處理實戰

原創作者:兩只蝸牛

責任編輯:林師授 來源: 兩只蝸牛的博客
相關推薦

2023-07-10 08:00:13

架構Rest返回值

2011-05-24 09:22:44

Spring3異常處理

2024-10-14 12:17:17

Flutter開源項目

2019-12-19 10:31:16

運維架構技術

2013-05-23 10:39:29

MVC架構MVC項目搭建

2021-12-05 18:18:20

linux

2017-08-19 23:21:14

線上CPU定位

2017-07-11 09:21:40

quartzshiro權限框架

2020-06-17 11:42:50

異常解析器Spring MVC

2023-11-17 09:02:51

Nacos配置中心

2024-01-03 09:22:19

2024-12-18 16:19:51

2020-04-28 09:40:51

MySQL數據庫命令

2023-02-23 08:15:33

Spring異常處理機制

2011-12-14 09:14:46

JavaJ2EESpring

2023-10-20 09:17:08

攜程實踐

2012-10-24 14:53:31

IBMdw

2021-02-02 15:58:02

Python爬蟲腳本

2009-04-03 09:26:35

ASP.NETMVC開源

2022-07-26 09:22:04

Python項目
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品福利视频 | 欧美成人猛片aaaaaaa | 中文字幕在线一区二区三区 | 久久免费精品视频 | 日本网站免费在线观看 | 午夜影院免费体验区 | 午夜日韩| 亚洲精品一区在线观看 | 成人中文字幕av | 精品乱码一区二区三四区视频 | 欧美日韩国产欧美 | 国家一级黄色片 | 欧美国产激情 | 天天干成人网 | 亚洲一区二区三区在线 | 91久久北条麻妃一区二区三区 | 成人精品久久日伦片大全免费 | 中文字幕成人网 | 一区二区在线免费播放 | 欧美五月婷婷 | 国产91久久久久久久免费 | 日本欧美国产 | 国产精品中文字幕在线 | 日韩欧美在线精品 | 欧美一级久久久猛烈a大片 日韩av免费在线观看 | 国产免费一区二区 | 久久在线免费 | 国产97视频在线观看 | 日韩视频一区二区三区 | 欧美激情视频一区二区三区在线播放 | 国内精品视频在线观看 | 在线第一页 | 日韩小视频在线 | 国产精品久久久久久久久免费高清 | 在线欧美一区 | 国产91丝袜在线播放 | av免费看片 | 免费一级做a爰片久久毛片潮喷 | 久久精品国产亚洲夜色av网站 | 亚洲高清在线视频 | 免费看的黄网站 |