Springboot2.0自定义拦截器

 在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/,该请求会被拦截,控制台会打印出:该请求已被拦截......

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,269评论 19 139
  • 对于java中的思考的方向,1必须要看前端的页面,对于前端的页面基本的逻辑,如果能理解最好,不理解也要知道几点。 ...
    神尤鲁道夫阅读 849评论 0 0
  • 昨晚和一朋友谈天中,谈到人的变化,我有感而发的说了一句:“人是会变的,你可以选择变好,也可以选择变坏,环境起不了主...
    辣帅阅读 1,331评论 0 1
  • 1.你不是懒,是不敢 “老子明年再干,我就叫你爸爸!”年前的最后3个月,每天下班回来,隔壁合租的夏哥就会跟我咆哮一...
    楼上的姨阅读 284评论 0 1