本篇文章给大家分享的是有关使用SpringMVC怎么实现一个全局异常处理器,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
首先,创建一个自定义的异常类
/**
* @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;
}
}
创建一个全局异常处理器的类,让它实现HandlerExceptionResolver 接口。相信,基础好一点的同学可以看出来我代码的意思(注释)
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 {
// 异常对象
ExceptionCustom exceptionCustom = null;
private Logger logger = Logger.getLogger(SimpleExceptionResolver.class
.getSimpleName());
/**
* 全局处理异常
*/
public ModelAndView resolveException(HttpServletRequest request,
HttpServletResponse response, Object handler, Exception ex) {
//转化为自定义异常
exceptionCustom = (ExceptionCustom) ex;
//判断是否是本地异常
if (ex instanceof ExceptionCustom) {
logger.info(ex.getMessage());
} else {
…抛出错误
}
//获取异常信息
String message = exceptionCustom.getMessage();
ModelAndView mv = new ModelAndView();
//将异常返回到Model
mv.addObject("xx", message);
// 指向错误页面
mv.setViewName("error");
return null;
}
}
解释一下,在判断一个异常是否是其他异常的时候,先看它是否属于本地异常(Exception)的exceptionCustom ,如果是本地异常,则抛出本地异常信息
if (ex instanceof ExceptionCustom) {
logger.info(ex.getMessage());
} else {
…抛出错误
}
如果不是本地异常,则抛出未知异常
然后从异常里面获取异常信息,将异常信息返回到MV中,最后转至页面,当然严谨一点的,会将异常信息添加到数据库中,方便查看
由于本文章只是一个Demo,所以没有考虑到很多因素
下来,说说配置文件
配置文件,先贴上代码,然后再做解释
<!-- 全局异常处理器 -->
<bean id="handlerExceptionResolver" class = "xxxx(包名).SimpleExceptionResolver"/>
注意:首先,这个bean将配置在自己的web层.xml(spring-web.xml),当启动tomcat,加载web.xml后需加载spring-web.xml
之前注入的bean的id我随便写了一个名称,然后spring解析的时候报错了,
之后看了源码的时候,才知道原来是这么回事
1SpringMVC 在org.springframework.web.servlet.DispatcherServlet类中声明了
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.
}
}
看完这段代码的同学应该就知道为什么把bean 的id 设置成handlerExceptionResolver了吧
HandlerExceptionResolver her =context.getBean(HANDLER_EXCEPTION_RESOLVER_BEAN_NAME, HandlerExceptionResolver.class);
所以说,全局异常处理器的bean的id不能随便的设置。
以上就是使用SpringMVC怎么实现一个全局异常处理器,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。