java学习之spring里的三大拦截器是什么?

如果下载的源码需要作者授权,请更换源码。本站免费分享资源不会增加授权

本篇文章给大家带来的内容是介绍spring里的三大拦截器是什么。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

Filter

新建 TimeFilter

@Component public class TimeFilter implements Filter {     @Override     public void init(FilterConfig filterConfig) throws ServletException {         System.out.println("time filter init");     }      @Override     public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {         System.out.println("time filter start");         long startTime = System.currentTimeMillis();          filterChain.doFilter(servletRequest, servletResponse);          long endTime = System.currentTimeMillis();         System.out.println("time filter consume " + (endTime - startTime) + " ms");         System.out.println("time filter end");     }      @Override     public void destroy() {         System.out.println("time filter init");     } }

启动服务器,在浏览器输入:http://localhost:8080/hello?name=tom

可以在控制台输出如下结果:

time filter start
name: tom
time filter consume 3 ms
time filter end

可以看到,filter 先执行,再到真正执行 HelloController.sayHello() 方法。
通过 TimeFilter.doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) 方法的参数可以看出,我们只能得到原始的 request 和 response对象,不能得到这个请求被哪个 Controller 以及哪个方法处理了,使用Interceptor 就可以获得这些信息。

Interceptor

新建 TimeInterceptor

@Component public class TimeInterceptor extends HandlerInterceptorAdapter {      private final NamedThreadLocal<Long> startTimeThreadLocal = new NamedThreadLocal<>("startTimeThreadLocal");      @Override     public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {         System.out.println("time interceptor preHandle");          HandlerMethod handlerMethod = (HandlerMethod) handler;         // 获取处理当前请求的 handler 信息         System.out.println("handler 类:" + handlerMethod.getBeanType().getName());         System.out.println("handler 方法:" + handlerMethod.getMethod().getName());          MethodParameter[] methodParameters = handlerMethod.getMethodParameters();         for (MethodParameter methodParameter : methodParameters) {             String parameterName = methodParameter.getParameterName();             // 只能获取参数的名称,不能获取到参数的值             //System.out.println("parameterName: " + parameterName);         }          // 把当前时间放入 threadLocal         startTimeThreadLocal.set(System.currentTimeMillis());          return true;     }      @Override     public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {         System.out.println("time interceptor postHandle");     }      @Override     public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {          // 从 threadLocal 取出刚才存入的 startTime         Long startTime = startTimeThreadLocal.get();         long endTime = System.currentTimeMillis();          System.out.println("time interceptor consume " + (endTime - startTime) + " ms");          System.out.println("time interceptor afterCompletion");     } }

注册 TimeInterceptor
把 TimeInterceptor 注入 spring 容器

@Configuration public class WebConfig extends WebMvcConfigurerAdapter {      @Autowired     private TimeInterceptor timeInterceptor;      @Override     public void addInterceptors(InterceptorRegistry registry) {         registry.addInterceptor(timeInterceptor);     } }

启动服务器,在浏览器输入:http://localhost:8080/hello?name=tom
可以在控制台输出如下结果:

time filter start time interceptor preHandle handler 类:com.nextyu.demo.web.controller.HelloController handler 方法:sayHello name: tom time interceptor postHandle time interceptor consume 40 ms time interceptor afterCompletion time filter consume 51 ms time filter end

可以看到,filter 先于 interceptor 执行,再到真正执行 HelloController.sayHello() 方法。通过 interceptor 方法上的 handler 参数,我们就可以得到这个请求被哪个 Controller 以及哪个方法处理了。但是不能直接获取到这个方法上的参数值(在这里就是 HelloController.sayHello(String name) 方法参数 name 的值),通过 Aspect 就可以获取到。

Aspcet

新建 TimeAspect

@Aspect @Component public class TimeAspect {      @Around("execution(* com.nextyu.demo.web.controller.*.*(..))")     public Object handleControllerMethod(ProceedingJoinPoint pjp) throws Throwable {          System.out.println("time aspect start");          Object[] args = pjp.getArgs();         for (Object arg : args) {             System.out.println("arg is " + arg);         }          long startTime = System.currentTimeMillis();          Object object = pjp.proceed();          long endTime = System.currentTimeMillis();         System.out.println("time aspect consume " + (endTime - startTime) + " ms");          System.out.println("time aspect end");          return object;     }  }

启动服务器,在浏览器输入:http://localhost:8080/hello?name=tom
可以在控制台输出如下结果:

time filter start time interceptor preHandle handler 类:com.nextyu.demo.web.controller.HelloController handler 方法:sayHello time aspect start arg is tom name: tom time aspect consume 0 ms time aspect end time interceptor postHandle time interceptor consume 2 ms time interceptor afterCompletion time filter consume 4 ms time filter end

可以看到,filter 先执行,再到 interceptor 执行,再到 aspect 执行,再到真正执行 HelloController.sayHello() 方法。
我们也获取到了 HelloController.sayHello(String name) 方法参数 name 的值

请求拦截过程图

graph TD httprequest-->filter filter-->interceptor interceptor-->aspect aspect-->controller
本文由(壳先生)整理自网络,如转载请注明出处:https://www.mrshell.com;
本站发布的内容若侵犯到您的权益,请邮件联系 i@mrshell.com 删除,我们将及时处理!
===========================================================================

1. 本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行测试。
2. 本站资源仅供学习和交流使用,版权归资源原作者所有,请在下载后24小时之内自觉删除。
3. 不得使用于非法商业用途,商用请支持正版!不得违反国家法律,否则后果自负!
4. 若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,与本站无关。
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!

=================================================================

壳先生 » java学习之spring里的三大拦截器是什么?

发表评论

提供最优质的资源集合

立即查看 了解详情