基于SpringMVC的全局异常处理器介绍
近几天又温习了一下SpringMVC的运行机制以及原理
我理解的springmvc,是设计模式MVC中C层,也就是Controller(控制)层,常用的注解有@Controller、@RequestMapping、@Autowared、@Component,今天呢,我所要写的是SpringMVC的全局异常处理器,关联的接口有HandlerExceptionResolver(Eclipse用户可以按Ctrl+Shift+T进行搜索该接口),什么是全局异常处理器?为什么要用它呢?
在企业开发中,各种的Runtime异常可能会让我们崩溃,但是还有一部分异常在此之外,因此我们就要捕获它,然后进行操作提示(将错误提示返回到ModelAndView)
下来呢,我贴一部分代码
首先呢,创建一个自定义的异常类
/**
*@Title:ExceptionCustom.java
*@Description:本地异常
*@authorChoviWu
*@versionV1.0
*/
publicclassExceptionCustomextendsException{
/**
*@FieldsserialVersionUID:
*/
privatestaticfinallongserialVersionUID=1L;
privateStringmessage;
/**
*@returnthemessage
*/
publicStringgetMessage(){
returnmessage;
}
/**
*@parammessagethemessagetoset
*/
publicvoidsetMessage(Stringmessage){
this.message=message;
}
publicExceptionCustom(){
super();
//TODOAuto-generatedconstructorstub
}
publicExceptionCustom(Stringmessage){
super(message);
this.message=message;
}
}
创建一个全局异常处理器的类,让它实现HandlerExceptionResolver接口。相信,基础好一点的同学可以看出来我代码的意思(注释)
importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;
importorg.apache.log4j.Logger;
org.springframework.web.servlet.HandlerExceptionResolver;
importorg.springframework.web.servlet.ModelAndView;
/**
*@Title:SimpleException.java
*@Description:全局异常处理器
*@authorChoviWu
*@versionV1.0
*/
publicclassSimpleExceptionResolverimplementsHandlerExceptionResolver{
//异常对象
ExceptionCustomexceptionCustom=null;
privateLoggerlogger=Logger.getLogger(SimpleExceptionResolver.class
.getSimpleName());
/**
*全局处理异常
*/
publicModelAndViewresolveException(HttpServletRequestrequest,
HttpServletResponseresponse,Objecthandler,Exceptionex){
//转化为自定义异常
exceptionCustom=(ExceptionCustom)ex;
//判断是否是本地异常
if(exinstanceofExceptionCustom){
logger.info(ex.getMessage());
}else{
…抛出错误
}
//获取异常信息
Stringmessage=exceptionCustom.getMessage();
ModelAndViewmv=newModelAndView();
//将异常返回到Model
mv.addObject("xx",message);
//指向错误页面
mv.setViewName("error");
returnnull;
}
}
解释一下,在判断一个异常是否是其他异常的时候,先看它是否属于本地异常(Exception)的exceptionCustom,如果是本地异常,则抛出本地异常信息
if(exinstanceofExceptionCustom){
logger.info(ex.getMessage());
}else{
…抛出错误
}
如果不是本地异常,则抛出未知异常
然后从异常里面获取异常信息,将异常信息返回到MV中,最后转至页面,当然严谨一点的,会将异常信息添加到数据库中,方便查看
由于本文章只是一个Demo,所以没有考虑到很多因素
下来,说说配置文件
配置文件,先贴上代码,然后再做解释
注意:首先,这个bean将配置在自己的web层.xml(spring-web.xml),当启动tomcat,加载web.xml后需加载spring-web.xml
之前注入的bean的id我随便写了一个名称,然后spring解析的时候报错了,
之后看了源码的时候,才知道原来是这么回事
1SpringMVC在org.springframework.web.servlet.DispatcherServlet类中声明了 publicstaticfinalStringHANDLER_EXCEPTION_RESOLVER_BEAN_NAME="handlerExceptionResolver";
privatevoidinitHandlerExceptionResolvers(ApplicationContextcontext){
this.handlerExceptionResolvers=null;
if(this.detectAllHandlerExceptionResolvers){
//FindallHandlerExceptionResolversintheApplicationContext,includingancestorcontexts.
MapmatchingBeans=BeanFactoryUtils
.beansOfTypeIncludingAncestors(context,HandlerExceptionResolver.class,true,false);
if(!matchingBeans.isEmpty()){
this.handlerExceptionResolvers=newArrayList(matchingBeans.values());
//WekeepHandlerExceptionResolversinsortedorder.
OrderComparator.sort(this.handlerExceptionResolvers);
}
}
else{
try{
HandlerExceptionResolverher=
context.getBean(HANDLER_EXCEPTION_RESOLVER_BEAN_NAME,HandlerExceptionResolver.class);
this.handlerExceptionResolvers=Collections.singletonList(her);
}
catch(NoSuchBeanDefinitionExceptionex){
//Ignore,noHandlerExceptionResolverisfinetoo.
}
}  
看完这段代码的同学应该就知道为什么把bean的id设置成handlerExceptionResolver了吧
HandlerExceptionResolverher=context.getBean(HANDLER_EXCEPTION_RESOLVER_BEAN_NAME,HandlerExceptionResolver.class);
所以说,全局异常处理器的bean的id不能随便的设置。
以上这篇基于SpringMVC的全局异常处理器介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
