SpringMVC异常处理
- 原理
- 解析:
- 系统中异常包括两类:预期异常和运行时异常 RuntimeException,前者通过捕获异常从而获取异常信息, 后者主要通过规范代码开发、测试通过手段减少运行时异常的发生
- 系统的 dao、service、controller 出现都通过 throws Exception 向上抛出,最后由 springmvc 前端 控制器交由异常处理器进行异常处理
- 实现步骤
- 自定义异常
// 一定要继承Exception
public class SysException extends Exception {
// 存储提示信息的
private String message;
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
public SysException(String message) {
this.message = message;
}
}
2. 自定义异常处理器
// 异常处理器,实现接口HandlerExceptionResolver
public class SysExceptionResolver implements HandlerExceptionResolver {
@Override
public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
SysException se = null;
// 判断是否是SysException异常
if (e instanceof SysException){
se = (SysException) e;
}
else {
e = new SysException("系统正在维护中。。。。。。");
}
ModelAndView mv = new ModelAndView();
mv.addObject("errorMsg", e.getMessage());
mv.setViewName("error");
return mv;
}
}
3. 异常跳转的jsp页面
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>${errorMsg}</h1>
</body>
</html>
4. controller里的方法
@RequestMapping("/testException")
public String testException() throws SysException {
try {
int a = 1/0;
}catch (Exception e){
e.printStackTrace();
throw new SysException("自定义异常处理测试");
}
return "success";
}
5. 结果
SpringMVC的拦截器
- 拦截器的作用
Spring MVC 的处理器拦截器类似于 Servlet 开发中的过滤器 Filter,用于对处理器进行预处理和后处理, 用户可以自己定义一些拦截器来实现特定的功能 - 拦截链
谈到拦截器,还要向大家提一个词——拦截器链(Interceptor Chain)。拦截器链就是将拦截器按一定的顺 序联结成一条链。在访问被拦截的方法或字段时,拦截器链中的拦截器就会按其之前定义的顺序被调用 - 拦截器和过滤器的区别
- 过滤器是 servlet 规范中的一部分,任何 java web 工程都可以使用
- 拦截器是 SpringMVC 框架自己的,只有使用了 SpringMVC 框架的工程才能用
- 过滤器在 url-pattern 中配置了/*之后,可以对所有要访问的资源拦截
- 拦截器它是只会拦截访问的控制器方法,如果访问的是 jsp,html,css,image 或者 js 是不会进行拦截的
- 它也是 AOP 思想的具体应用,我们要想自定义拦截器, 要求必须实现:HandlerInterceptor 接口
- 自定义拦截器的步骤
- 创建HandleInterceptor实现类
public class HandlerInterceptorDemo1 implements HandlerInterceptor {
/**
* 预处理,controller执行前执行
* return true :放行,执行下一个拦截器,如果没有就执行controller中的方法
* return false :不放行
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("拦截器1:preHandle执行了。。。。。。");
return true;
}
/**
* 后处理方法,在controller方法执行后执行,在页面执行前执行
* 如果有第二个拦截器的话,第二个拦截器先执行,以此类推
*/
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("拦截器1:postHandle执行了。。。。。。");
}
/**
* 在页面执行后执行
* 如果有第二个拦截器的话,第二个拦截器先执行,以此类推
* 可以做一些资源清除的工作
*/
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("拦截器1:afterCompletion执行了。。。。。。");
}
}
- 配置springmvc.xml
<!--配置拦截器-->
<mvc:interceptors>
<!--配置一个拦截器-->
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean id="handlerInterceptorDemo1" class="com.zsc.Interceptor.HandlerInterceptorDemo1"/>
</mvc:interceptor>
</mvc:interceptors>
- 结果
- 若配置多个拦截器(拦截链)
新建HandleInterceptor实现类(同上),在springmvc.xml的< mvc:interceptors >里增加配置即可(也同上) - 拦截链的执行结果(主意执行顺序)
- 执行顺序