基于SpringMVC的全局異常處理器介紹
近幾天又溫習(xí)了一下SpringMVC的運(yùn)行機(jī)制以及原理
我理解的springmvc,是設(shè)計(jì)模式MVC中C層,也就是Controller(控制)層,常用的注解有@Controller、@RequestMapping、@Autowared、@Component,今天呢,我所要寫(xiě)的是SpringMVC的全局異常處理器,關(guān)聯(lián)的接口有HandlerExceptionResolver(Eclipse用戶可以按Ctrl+Shift+T進(jìn)行搜索該接口),什么是全局異常處理器?為什么要用它呢?
在企業(yè)開(kāi)發(fā)中,各種的Runtime異??赡軙?huì)讓我們崩潰,但是還有一部分異常在此之外,因此我們就要捕獲它,然后進(jìn)行操作提示(將錯(cuò)誤提示返回到ModelAndView)
下來(lái)呢,我貼一部分代碼
首先呢,創(chuàng)建一個(gè)自定義的異常類(lèi)
/** * @Title: ExceptionCustom.java * @Description: 本地異常 * @author ChoviWu * @version V1.0 */ public class ExceptionCustom extends Exception{ /** * @Fields serialVersionUID : */ private static final long serialVersionUID = 1L; private String message; /** * @return the message */ public String getMessage() { return message; } /** * @param message the message to set */ public void setMessage(String message) { this.message = message; } public ExceptionCustom() { super(); // TODO Auto-generated constructor stub } public ExceptionCustom(String message) { super(message); this.message = message; } }
創(chuàng)建一個(gè)全局異常處理器的類(lèi),讓它實(shí)現(xiàn)HandlerExceptionResolver 接口。相信,基礎(chǔ)好一點(diǎn)的同學(xué)可以看出來(lái)我代碼的意思(注釋?zhuān)?/p>
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.log4j.Logger; org.springframework.web.servlet.HandlerExceptionResolver; import org.springframework.web.servlet.ModelAndView; /** * @Title: SimpleException.java * @Description:全局異常處理器 * @author ChoviWu * @version V1.0 */ public class SimpleExceptionResolver implements HandlerExceptionResolver { // 異常對(duì)象 ExceptionCustom exceptionCustom = null; private Logger logger = Logger.getLogger(SimpleExceptionResolver.class .getSimpleName()); /** * 全局處理異常 */ public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) { //轉(zhuǎn)化為自定義異常 exceptionCustom = (ExceptionCustom) ex; //判斷是否是本地異常 if (ex instanceof ExceptionCustom) { logger.info(ex.getMessage()); } else { …拋出錯(cuò)誤 } //獲取異常信息 String message = exceptionCustom.getMessage(); ModelAndView mv = new ModelAndView(); //將異常返回到Model mv.addObject("xx", message); // 指向錯(cuò)誤頁(yè)面 mv.setViewName("error"); return null; } }
解釋一下,在判斷一個(gè)異常是否是其他異常的時(shí)候,先看它是否屬于本地異常(Exception)的exceptionCustom ,如果是本地異常,則拋出本地異常信息
if (ex instanceof ExceptionCustom) { logger.info(ex.getMessage()); } else { …拋出錯(cuò)誤 }
如果不是本地異常,則拋出未知異常
然后從異常里面獲取異常信息,將異常信息返回到MV中,最后轉(zhuǎn)至頁(yè)面,當(dāng)然嚴(yán)謹(jǐn)一點(diǎn)的,會(huì)將異常信息添加到數(shù)據(jù)庫(kù)中,方便查看
由于本文章只是一個(gè)Demo,所以沒(méi)有考慮到很多因素
下來(lái),說(shuō)說(shuō)配置文件
配置文件,先貼上代碼,然后再做解釋
<!-- 全局異常處理器 --> <bean id="handlerExceptionResolver" class = "xxxx(包名).SimpleExceptionResolver"/>
注意:首先,這個(gè)bean將配置在自己的web層.xml(spring-web.xml),當(dāng)啟動(dòng)tomcat,加載web.xml后需加載spring-web.xml
之前注入的bean的id我隨便寫(xiě)了一個(gè)名稱(chēng),然后spring解析的時(shí)候報(bào)錯(cuò)了,
之后看了源碼的時(shí)候,才知道原來(lái)是這么回事
1SpringMVC 在org.springframework.web.servlet.DispatcherServlet類(lèi)中聲明了 public static final String HANDLER_EXCEPTION_RESOLVER_BEAN_NAME = "handlerExceptionResolver";
private void initHandlerExceptionResolvers(ApplicationContext context) { this.handlerExceptionResolvers = null; if (this.detectAllHandlerExceptionResolvers) { // Find all HandlerExceptionResolvers in the ApplicationContext, including ancestor contexts. Map<String, HandlerExceptionResolver> matchingBeans = BeanFactoryUtils .beansOfTypeIncludingAncestors(context, HandlerExceptionResolver.class, true, false); if (!matchingBeans.isEmpty()) { this.handlerExceptionResolvers = new ArrayList<HandlerExceptionResolver>(matchingBeans.values()); // We keep HandlerExceptionResolvers in sorted order. OrderComparator.sort(this.handlerExceptionResolvers); } } else { try { HandlerExceptionResolver her = context.getBean(HANDLER_EXCEPTION_RESOLVER_BEAN_NAME, HandlerExceptionResolver.class); this.handlerExceptionResolvers = Collections.singletonList(her); } catch (NoSuchBeanDefinitionException ex) { // Ignore, no HandlerExceptionResolver is fine too. } }
看完這段代碼的同學(xué)應(yīng)該就知道為什么把bean 的id 設(shè)置成handlerExceptionResolver了吧
HandlerExceptionResolver her =context.getBean(HANDLER_EXCEPTION_RESOLVER_BEAN_NAME, HandlerExceptionResolver.class);
所以說(shuō),全局異常處理器的bean的id不能隨便的設(shè)置。
以上這篇基于SpringMVC的全局異常處理器介紹就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java實(shí)現(xiàn)簡(jiǎn)易版猜燈謎游戲的示例代碼
燈謎是中秋節(jié)傳統(tǒng)的活動(dòng)之一,而現(xiàn)代化的方式則是將其制作成一個(gè)小游戲,讓用戶在游戲的過(guò)程中猜燈謎,互動(dòng)體驗(yàn)更佳,所以本文小編就用Java制作一款猜燈謎小游戲吧2023-09-09Spring5源碼解析之Spring中的異步和計(jì)劃任務(wù)
本篇文章主要介紹了Spring5源碼解析之Spring中的異步和計(jì)劃任務(wù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-10-10Guava事件總線應(yīng)用場(chǎng)景最佳實(shí)踐
這篇文章主要為大家介紹了Guava事件總線應(yīng)用場(chǎng)景最佳實(shí)踐,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Java實(shí)戰(zhàn)練習(xí)之撲克牌魔術(shù)
這篇文章主要介紹了Java實(shí)戰(zhàn)練習(xí)之撲克牌魔術(shù),文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們有很好地幫助,需要的朋友可以參考下2021-04-04從Mybatis-Plus開(kāi)始認(rèn)識(shí)SerializedLambda的詳細(xì)過(guò)程
這篇文章主要介紹了從Mybatis-Plus開(kāi)始認(rèn)識(shí)SerializedLambda,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07