(三)、SpringBoot 自定义 interceptor(拦截器)
2018-03-12 11:52
666 查看
可以前往第一篇博客查看目录结构 --> 这里
一、创建interceptor包
二、在interceptor包下创建TimeInterceptor类,自定义Interceptor@Component
public class TimeInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("interceptor preHandle");
System.out.println(((HandlerMethod)handler).getBean().getClass().getName());
System.out.println(((HandlerMethod)handler).getMethod().getName());
request.setAttribute("start",new Date().getTime());
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("interceptor postHandle");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("interceptor afterCompletion");
long start = (long) request.getAttribute("start");
System.out.println("interceptor耗时: " + (new Date().getTime() - start));
}
}
三、在config包下的WebConfig类下添加下述代码,配置自定义的TimeInterceptor进入 @Autowired
private TimeInterceptor timeInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(timeInterceptor);
}
四、访问 localhost/user ,查看IDEA控制台即可
一、创建interceptor包
二、在interceptor包下创建TimeInterceptor类,自定义Interceptor@Component
public class TimeInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("interceptor preHandle");
System.out.println(((HandlerMethod)handler).getBean().getClass().getName());
System.out.println(((HandlerMethod)handler).getMethod().getName());
request.setAttribute("start",new Date().getTime());
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("interceptor postHandle");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("interceptor afterCompletion");
long start = (long) request.getAttribute("start");
System.out.println("interceptor耗时: " + (new Date().getTime() - start));
}
}
三、在config包下的WebConfig类下添加下述代码,配置自定义的TimeInterceptor进入 @Autowired
private TimeInterceptor timeInterceptor;
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(timeInterceptor);
}
四、访问 localhost/user ,查看IDEA控制台即可
相关文章推荐
- springboot自定义拦截器Interceptor
- SpringBoot添加自定义拦截器的实现代码
- spring-boot 加入拦截器Interceptor
- spring boot-实现WebService(CXF实现)的拦截器(Interceptor)
- springboot 配置使用拦截器 interceptor
- spring boot框架学习8-【干货】spring boot的web开发(4)-自定义拦截器处理权限
- SpringBoot:拦截器的使用Interceptor,实现对404和500拦截
- spring boot框架学习8-【干货】spring boot的web开发(4)-自定义拦截器处理权限
- SpringBoot使用自定义注解+拦截器 实现日志记录
- Spring boot自定义注解拦截器
- SpringBoot之Interceptor拦截器
- spring-boot 加入拦截器Interceptor
- spring-boot添加自定义拦截器
- spring boot LoginInterceptor(登录拦截器)无法注入bean
- spring boot框架学习8-【干货】spring boot的web开发(4)-自定义拦截器处理权限
- 实现SpringBoot自定义拦截器
- spring boot 中使用spring mvc interceptor(拦截器)判断操作权限
- springboot的interceptor(拦截器)的应用
- SpringBoot之Interceptor拦截器
- Spring Boot使用拦截器Interceptor