一、定义拦截器
定义拦截器,需要实现 HandlerInterceptor 接口。HandlerInterceptor 接口是 Spring Boot 提供的拦截器的父类。该接口中有三个方法。preHandle、postHandle、afterCompletion。
- preHandle:某个 URL 匹配到对应的 Controller 中的某个方法,且在这个方法执行之前。该方法可以决定是否将请求放行。返回 true 则放行,返回 false 则不会向后执行。
- postHandle:某个 URL 已经匹配到对应的 Controller 中的某个方法,且在执行完了该方法,但是在 DispatcherServlet 视图渲染之前。所以在这个方法中有个 ModelAndView 参数,可以在此做一些修改动作。
- afterCompletion:在整个请求处理完成后(包括视图渲染)执行,这时做一些资源的清理工作,这个方法只有在preHandle被成功执行后并且返回 true 才会被执行。
简单应用:
preHandle拦截请求,检查header中是否包含verify属性,初步的拦截意外请求
/**
* 身份验证拦截器
* 初步拦截第三方请求服务器
*
* @author chenyi
* Create on 2019/5/10
*/
@Component
public class VerifyInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
String verify = request.getHeader("verify");
if (verify.equals("verify")) {
return true;
}
response.sendRedirect("zy/error/illegalRequest");
return false;
}
}
二、配置拦截器
/**
* 配置拦截器
*
* @author chenyi
* Create on 2019/5/10
*/
@Configuration
public class InterceptorConfig implements WebMvcConfigurer {
/**
* 验证拦截器(上面写的)
*/
@Resource
private VerifyInterceptor verifyInterceptor;
/**
* 添加自定义拦截器
*/
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(verifyInterceptor).addPathPatterns("/api/**");
}
}
至此,拦截器已经配置生效。
来源:CSDN
作者:chenyi406
链接:https://blog.csdn.net/chenyi406/article/details/103722301