1. 拦截器概述
拦截器的作用:
SpringMVC的处理拦截器类似于Servlet开发中的过滤器Filter,用于对处理器(controller)进行预处理和后处理。
拦截器与过滤器的区别
- 过滤器是servlet规范中的一部分,任何java web工程都可以使用。
- 拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能用。
- 过滤器在url-pattern中配置了/*之后,可以对所有要访问的资源拦截。
- 拦截器它是只会拦截访问的控制器方法,如果访问的是jsp,html,css,image或者js是不会进行拦截的。
它也是AOP思想的具体应用。
谈到拦截器,还要向大家提一个词-----拦截器链(Interceptor Chain)。拦截器链就是将拦截器按一定的顺序联结成一条链。在访问被拦截的方法时,拦截器链中的拦截器就会被其之前定义的顺序被调用。
2.自定义拦截器
自定义拦截器步骤:
1 编写拦截器的类,必须实现HandlerInterceptor接口
2 配置拦截器
拦截器类代码:
/**
* 自定义拦截器
* 实现接口没有报错不用写方法的原因,jdk1.8对接口做了增强,
*/
public class MyInterceptor1 implements HandlerInterceptor{
/**
* 预处理,controller方法执行前,进行一些判断
* return true 放行,执行下一个拦截器,如果没有,执行controller中的方法
* return false 不放行
* @param request
* @param response
* @param handler
* @return
* @throws Exception
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("MyInterceptor1执行了...前1111");
return true;
//request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request, response);
//return false;
}
/**
* 后处理方法,controller方法执行后,success.jsp执行之前
* @param request
* @param response
* @param handler
* @param modelAndView
* @throws Exception
*/
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception {
System.out.println("MyInterceptor1执行了...后1111");
//request.getRequestDispatcher("/WEB-INF/pages/error.jsp").forward(request, response);
}
/**
* success.jsp页面执行之后,该方法会执行,通常会在此释放一些资源或流
* @param request
* @param response
* @param handler
* @param ex
* @throws Exception
*/
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception {
System.out.println("MyInterceptor1执行了...最后1111");
}
}
配置拦截器:
success.jsp代码:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h3>成功页面</h3>
<% System.out.println("success.jsp执行了"); %>
</body>
</html>
输出结果: