SpringMVC中的拦截器与异常处理机制详解
作者:咕咕猫_
一、SpringMVC拦截器
1.1 拦截器(interceptor)的作用
SpringMVC的拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理
将拦截器按一定的顺序联结成一条链,这条链被称为拦截器链(Interceptor Chain)。在访问被拦截的方法或字段时,拦截器链中的拦截器就会按其之前定义的顺序被调用。拦截器也是AOP思想的具体实现。
1.2 拦截器和过滤器区别
| 区别 | 过滤器(Filter) | 拦截器(Interceptor) |
| 使用范围 | 是 servlet 规范中的一部分,任何 Java Web 工程都可以使用 | 是 SpringMVC 框架自己的,只有使用了 SpringMVC 框架的工程才能用 |
| 拦截范围 | 在 url-pattern 中配置了/*之后, 可以对所有要访问的资源拦截 | 在<mvc:mapping path= "" />中配置了/**之后,也可以多所有资源进行拦截,但是可以通过<mvc:exclude-mapping path= "" />标签排除不需要拦截的资源 |
1.3 拦截器快速入门
自定义拦截器三个步骤
①创建拦截器类实现HandlerInterceptor接口
②配置拦截器
③测试拦截器的拦截效果
代码实现
① 创建拦截器类实现HandlerInterceptor接口
public class MyInterceptor1 implements HandlerInterceptor {
@Override
//在目标方法执行之前 执行
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle...");
String param = request.getParameter("param");
if ("yes".equals(param)){
return true;
}else {
request.getRequestDispatcher("/error.jsp").forward(request,response);
return false;
}
//return true; //返回true表示放行,返回false表示不放行
}
@Override
//在目标方法执行之后,视图对象返回之前 执行
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
modelAndView.addObject("name","我被改了~");
System.out.println("postHandle...");
}
@Override
//在流程都执行完毕后 执行
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("afterCompletion...");
}
}
② 配置拦截器
<!--配置拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!--对哪些资源执行拦截操作-->
<mvc:mapping path="/**"/>
<bean class="com.learn.interceptor.MyInterceptor1"/>
</mvc:interceptor>
</mvc:interceptors>③ 测试拦截器的拦截效果(编写目标方法)
@Controller
public class TargetController {
@RequestMapping("/target")
public ModelAndView show(){
System.out.println("目标资源执行...");
ModelAndView modelAndView = new ModelAndView();
modelAndView.addObject("name","gugumao");
modelAndView.setViewName("index");
return modelAndView;
}
}这里url不带param参数或者param参数不为yes的话会跳转到error.jsp页面中


控制台打印顺序如下:

1.4 多拦截器操作
同上,再编写一个MyHandlerInterceptor2操作,测试执行顺序如下:

1.5 拦截器方法说明
| 方法名 | 说明 |
| preHandle() | 方法将在请求处理之前进行调用,该方法的返回值是布尔值Boolean类型的, 当它返回为 false 时,表示请求结束,后续的Interceptor 和Controller 都不会再执行;当返回值为true 时就会继续调用下一个Interceptor 的 preHandle 方法 |
| postHandle() | 该方法是在当前请求进行处理之后被调用,前提是 preHandle 方法的返回值为 true 时才能被调用,且它会在DispatcherServlet 进行视图返回渲染之前被调用,所以我们可以在这个方法中对Controller 处理之后的ModelAndView 对象进行操作 |
| afterCompletion() | 该方法将在整个请求结束之后,也就是在DispatcherServlet 渲染了对应的视图之后执行,前提是 preHandle 方法的返回值为true时才能被调用 |
二、SpringMVC异常处理机制
2.1 异常处理的思路
系统中异常包括两类:预期异常和运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发、测试等手段减少运行时异常的发生
系统的DAO、Service、Controller出现都通过throws Exception向上抛出,最后由SpringMVC前端控制器交由异常处理器进行异常处理,如下图:

2.2 异常处理的两种方式
- 使用SpringMVC提供的简单异常处理器 SimpleMappingExceptionResolver
- 实现Spring的异常处理接口 HandlerExceptionRosolver 自定义自己的异常处理器
2.2.1 简单异常处理器 SimpleMappingExceptionResolver
SpringMVC已经定义好了该类型转换器,在使用时可以根据项目情况进行相应异常与视图的映射配置
<!--配置简单映射异常处理器-->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="defaultErrorView" value="error"/>
<property name="exceptionMappings">
<map>
<entry key="java.lang.ClassCastException" value="error1"/>
<entry key="com.learn.exception.MyException" value="error2"/>
</map>
</property>
</bean>
2.2.2 自定义异常处理步骤
①创建异常处理器实现HandlerExceptionResolver接口
②配置异常处理器
③编写异常页面
④测试异常跳转
代码实现
创建异常处理器类实现HandlerExceptionResolver
public class MyExceptionResolver implements HandlerExceptionResolver {
/*
参数Exception:异常对象
返回值ModelAndView:跳转到错误视图信息
*/
public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
//处理异常的代码实现
//创建ModelAndView对象
ModelAndView modelAndView = new ModelAndView();
if(e instanceof MyException){
modelAndView.addObject("info","自定义异常");
}else if(e instanceof ClassCastException){
modelAndView.addObject("info","类转换异常");
}
modelAndView.setViewName("error");
return modelAndView;
}
}配置异常处理器
<!--自定义异常处理器-->
<bean class="com.learn.resolver.MyExceptionResolver"/>编写异常页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>通用的错误提示页面</h1>
<h1>${info}</h1>
</body>
</html>测试异常跳转
@Controller
public class DemoController {
@Autowired
private DemoService demoService;
@RequestMapping(value = "/show")
public String show() throws FileNotFoundException, MyException {
System.out.println("show running......");
//demoService.show1();
//demoService.show2();
//demoService.show3();
//demoService.show4();
demoService.show5();
return "index";
}
}到此这篇关于SpringMVC中的拦截器与异常处理机制详解的文章就介绍到这了,更多相关SpringMVC拦截器与异常处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
