拦截器
1、什么是拦截器
- interceptor
- 继承HandlerInterceptor的类
- 与过滤器相似
- 只拦截controller请求
- springmvc独有
2、编写拦截器
- 新建moudule
- 编写web.xml
- 编写springmvc-servlet.xml
编写MyInterceptor
- preHandle在请求的方法之前执行
- 返回值是true执行该controller,继续下一个拦截器
- 返回值为false不执行,不会走下一个拦截器
- postHandle和afterCompletion可用作日志
package com.kuang.interceptor;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class MyInterceptor implements HandlerInterceptor {
//拦截前
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("=========拦截前=========");
return true;
}
//在请求处理方法执行之后执行
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
//在dispatcherServlet处理后执行,做清理工作
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
在springmvc下配置interceptor
- 与filter类似
- 拦截什么?
- 拦截器是哪个?
<!--拦截器配置-->
<mvc:interceptors>
<mvc:interceptor>
<!--/** 包括路径及其子路径-->
<!--/admin/* 拦截的是/admin/add等等这种 , /admin/add/user不会被拦截-->
<!--/admin/** 拦截的是/admin/下的所有-->
<mvc:mapping path="/**"/>
<bean class="com.kuang.interceptor.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
编写controller接受请求
package com.kuang.controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class TestController {
@GetMapping("/t1")
public String test1(){
System.out.println("test1执行了");
return "ok";
}
}
3、拦截测试