在JavaEE中,经常用filter来做拦截器,后来有了SpringMvc,我们使用HandlerInterceptor进行拦截,现在有了Springboot,我们也使用HandlerInterceptor进行拦截,但我们不用xml的配置了,省去很多的事情。
1、自定义拦截器
public class TestInterceptor implements HandlerInterceptor {
/**
* 目标方法执行之前执行
*
* @param request
* @param response
* @param handler
* @return
*/
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
if (true) {
System.out.println("该请求已被拦截......");
return false;
}
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
}
}
如果拦截成功,控制台会打印:该请求已被拦截......
2、配置拦截器
在springmvc中,使用xml进行配置,但在springboot中,这里使用java配置,具体如下:
/**
* 使用WebMvcConfigurer可以来扩展SpringMVC的功能
*
* 在spring5.0之前可以继承WebMvcConfigurerAdapter此适配器进行配置,但spring5.0以后此适配器就被废弃(已被标注为@Deprecated),
* 目前有两种解决方案,一种是直接实现WebMvcConfigurer,另一种是直接继承WebMvcConfigurationSupport,官方推荐第一种方案。
*/
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
/**
* 自定义拦截规则
*
* @param registry
*/
@Override
public void addInterceptors(InterceptorRegistry registry) {
// addPathPatterns - 用于添加拦截规则
// excludePathPatterns - 用户排除拦截
registry.addInterceptor(new TestInterceptor())
.addPathPatterns("/**")
.excludePathPatterns("/index.html", "/", "/user/login");
}
}
上面自定义的拦截规则,首先我们使用 addPathPatterns("/**"); 添加对所有请求都拦截;然后在使用excludePathPatterns("/index.html", "/", "/user/login"); 将index.html和/user/login两个url设置不拦截。
3、Controller测试
@RestController
public class TestController {
@RequestMapping("/user/login")
public String hello() {
return "User Login!";
}
@RequestMapping("/hello")
public String world() {
return "Hello World!";
}
}
测试结果如下:
在浏览器输入:http://localhost:8088/user/login,该链接不会被拦截,在页面输出:User Login!
在浏览器输入:http://localhost:8088/,该请求会被拦截,控制台会打印出:该请求已被拦截......