SpringMVC統(tǒng)一異常處理三種方法詳解
這篇文章主要介紹了SpringMVC-統(tǒng)一異常處理三種方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
在 Spring MVC 應(yīng)用的開發(fā)中,不管是對底層數(shù)據(jù)庫操作,還是業(yè)務(wù)層或控制層操作,都會不可避免地遇到各種可預(yù)知的、不可預(yù)知的異常需要處理。
如果每個過程都單獨處理異常,那么系統(tǒng)的代碼耦合度高,工作量大且不好統(tǒng)一,以后維護的工作量也很大。
如果能將所有類型的異常處理從各層中解耦出來,這樣既保證了相關(guān)處理過程的功能單一,又實現(xiàn)了異常信息的統(tǒng)一處理和維護。
幸運的是,Spring MVC 框架支持這樣的實現(xiàn)。Spring MVC 統(tǒng)一異常處理有以下 3 種方式:
- 使用 Spring MVC 提供的簡單異常處理器 SimpleMappingExceptionResolver。
- 實現(xiàn) Spring 的異常處理接口 HandlerExceptionResolver 自定義自己的異常處理器。
- 使用 @ExceptionHandler 注解實現(xiàn)異常處理
本節(jié)主要根據(jù)這 3 種處理方式講解 Spring MVC 應(yīng)用的異常統(tǒng)一處理。
Spring MVC使用SimpleMappingExceptionResolver類異常處理
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring一beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 使用掃描機制掃描包 -->
<context:component-scan base-package="controller" />
<context:component-scan base-package="service" />
<context:component-scan base-package="dao" />
<!-- 配置視圖解析器 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver"
id="internalResourceViewResolver">
<!--前綴 -->
<property name="prefix" value="/WEB-INF/jsp/" />
<!-- 后綴 -->
<property name="suffix" value=".jsp" />
</bean>
<!--SimpleMappingExceptionResolver(異常類與 View 的對應(yīng)關(guān)系) -->
<bean
class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<!-- 定義默認的異常處理頁面,當該異常類型注冊時使用 -->
<property name="defaultErrorView" value="error"></property>
<!-- 定義異常處理頁面用來獲取異常信息的變量名,默認名為exception -->
<property name="exceptionAttribute" value="ex"></property>
<!-- 定義需要特殊處理的異常,用類名或完全路徑名作為key,異常頁名作為值 -->
<property name="exceptionMappings">
<props>
<prop key="exception.MyException">my-error</prop>
<prop key="java.sql.SQLException">sql-error</prop>
<!-- 在這里還可以繼續(xù)擴展對不同異常類型的處理 -->
</props>
</property>
</bean>
</beans>
Spring MVC使用HandlerExceptionResolver接口異常處理
package exception;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.ModelAndView;
public class MyExceptionHandler implements HandlerExceptionResolver {
@Override
public ModelAndView resolveException(HttpServletRequest arg0,
HttpServletResponse arg1, Object arg2, Exception arg3) {
Map<String, Object> model = new HashMap<String, Object>();
model.put("ex", arg3);
// 根據(jù)不同錯誤轉(zhuǎn)向不同頁面(統(tǒng)一處理),即異常與View的對應(yīng)關(guān)系
if (arg3 instanceof MyException) {
return new ModelAndView("my-error", model);
} else if (arg3 instanceof SQLException) {
return new ModelAndView("sql-error", model);
} else {
return new ModelAndView("error", model);
}
}
}
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring一beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 使用掃描機制掃描包 -->
<context:component-scan base-package="controller" />
<context:component-scan base-package="service" />
<context:component-scan base-package="dao" />
<!-- 配置視圖解析器 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver"
id="internalResourceViewResolver">
<!--前綴 -->
<property name="prefix" value="/WEB-INF/jsp/" />
<!-- 后綴 -->
<property name="suffix" value=".jsp" />
</bean>
<!--托管MyExceptionHandler-->
<bean class="exception.MyExceptionHandler"/>
</beans>
Spring MVC使用@ExceptionHandler注解異常處理
package controller;
import java.sql.SQLException;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.bind.annotation.ExceptionHandler;
import exception.MyException;
public class BaseController {
/** 基于@ExceptionHandler異常處理 */
@ExceptionHandler
public String exception(HttpServletRequest request, Exception ex) {
request.setAttribute("ex", ex);
// 根據(jù)不同錯誤轉(zhuǎn)向不同頁面,即異常與view的對應(yīng)關(guān)系
if (ex instanceof SQLException) {
return "sql-error";
} else if (ex instanceof MyException) {
return "my-error";
} else {
return "error";
}
}
}
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring一beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 使用掃描機制掃描包 -->
<context:component-scan base-package="controller" />
<context:component-scan base-package="service" />
<context:component-scan base-package="dao" />
<!-- 配置視圖解析器 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver"
id="internalResourceViewResolver">
<!--前綴 -->
<property name="prefix" value="/WEB-INF/jsp/" />
<!-- 后綴 -->
<property name="suffix" value=".jsp" />
</bean>
</beans>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
sql server 2008安裝失敗的解決辦法 徹底卸載老版本!
這篇文章主要介紹了sql server 2008安裝失敗的解決辦法:徹底卸載老版本!感興趣的小伙伴們可以參考一下2016-08-08
Microsoft SQL Server 2008安裝圖解教程(Windows 7)
本文詳細介紹了SQL Server 2008的完整安裝過程,但未介紹關(guān)于SP1補丁安裝說明,在Windows 7系統(tǒng)上運行必須安裝此補丁,對于部分服務(wù)的配置也未做詳細的介紹2012-07-07
SQL2008中 阻止保存要求重新創(chuàng)建表的更改 的解決方法
當用戶在在SQL Server 2008企業(yè)管理器中更改表結(jié)構(gòu)時,必須要先刪除原來的表,然后重新創(chuàng)建新表,才能完成表的更改2009-06-06
SQL Server 2008 Express 及 Management Studio Express下載安裝配置教程
這篇文章主要講如何一步步從下載、安裝、配置 SQL Server 2008 Express 和 SMSS 到最后 使用 SMSS 連接本地的數(shù)據(jù)庫服務(wù),需要的朋友可以參考下2020-08-08
SQL Server2008 數(shù)據(jù)庫誤刪除數(shù)據(jù)的恢復(fù)方法分享
今天有個朋友很著急地打電話給我,他用delete語句誤刪除了SQL Server 2008數(shù)據(jù)庫中兩個表中的所有記錄,而這個數(shù)據(jù)庫之前沒有任何備份。讓我?guī)退鉀Q一下,不然他要賠償客戶很多錢2011-10-10

