您好,登录后才能下订单哦!
本篇文章给大家分享的是有关使用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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。