【SpringBoot系列】WebMvcConfigurer配置

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

博客目录

一.基本介绍

1.WebMvcConfigurer 介绍

在 Spring MVC 框架中,WebMvcConfigurer 是一个非常重要的接口,它允许开发者通过 Java 配置的方式对 Spring MVC 进行定制化设置。addInterceptors 方法是 WebMvcConfigurer 接口中用于注册拦截器的关键方法,它使得开发者可以在请求处理流程中的不同阶段插入自定义逻辑,例如权限验证、日志记录等。以下是对 addInterceptors 方法的详细解析,以及如何使用它来增强你的 Web 应用程序。

2.拦截器的作用

拦截器在 Spring MVC 中主要用于以下场景:

  1. 日志记录:在请求处理前后记录日志,便于问题追踪和性能监控。
  2. 权限检查:确保用户请求的合法性,拦截未授权访问。
  3. 数据预处理:在请求到达控制器之前,对请求参数进行预处理或验证。
  4. 性能监控:统计请求处理时间,优化应用性能。

3.InterceptorRegistry

InterceptorRegistry 是 Spring MVC 配置中用于注册拦截器的类。它提供了一系列方法来配置拦截器的行为,包括指定拦截哪些请求路径以及排除哪些请求路径。以下是 InterceptorRegistry 的一些主要方法:

  1. addInterceptor : 用于添加一个拦截器实例。这个方法接受一个实现了 HandlerInterceptor 接口的实例,并返回一个 InterceptorRegistration 对象,允许进一步配置该拦截器,例如添加 URL 模式和排除模式。

  2. addWebRequestInterceptor : 这个方法与 addInterceptor 类似,也是用于添加拦截器,但它专门用于实现 WebRequestInterceptor 接口的拦截器。

  3. getInterceptors: 该方法返回所有注册的拦截器列表。这可以用于检查哪些拦截器已经配置在应用程序中。

  4. addPathPatterns: 这是一个链式调用的方法,用于指定拦截器应该应用到的 URL 路径模式。可以调用多次来添加多个路径模式。

  5. excludePathPatterns : 与 addPathPatterns 相对应,这个方法用来排除某些路径模式,让拦截器不会应用到这些路径上。

  6. order: 允许指定拦截器的顺序。数字越小,优先级越高。

通过这些方法,开发者可以根据需要配置拦截器的行为,以满足不同的业务场景。例如,可以创建一个自定义的 HandlerInterceptor 实现,并使用 InterceptorRegistry 来注册这个拦截器,同时指定它应该拦截的请求路径以及排除的请求路径。这样,当请求进入应用程序时,注册的拦截器就会按照配置的规则进行请求的预处理、后处理以及完成后的处理。

二.实战演练

1.配置文件

apl 复制代码
@Configuration
public class WebMvcConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        // 配置myInterceptor的拦截规范(如拦截的路径等等)
        registry.addInterceptor(new AuthInterceptor())
                // 设置需要拦截的路径(这里拦截所有的路径)
                .addPathPatterns("/**")
                // 设置书籍放行
                .excludePathPatterns("/bookInfo/**")
                // 设置登录放行
                .excludePathPatterns("/login", "/getOpenId", "/register")
                // 设置Swagger访问放行
                .excludePathPatterns("/api-docs", "/swagger-ui.html/**", "/swagger-ui.html", "/swagger-resources/**", "/swagger-ui.html#/**")
                // 如资源文件放行
                .excludePathPatterns("/webjars/**", "/doc.html", "classpath:/META-INF/resources/");
    }
}

2.处理拦截器

apl 复制代码
@Component
public class AuthInterceptor implements HandlerInterceptor {

    @Autowired
    private NewSpaceJedisClient belleJedisClient;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        // 如果请求的URL不包含排除路径,则进行Token验证
        String token = request.getHeader("Authorization");
        if (token == null || token.isEmpty()) {
            // 如果没有Token,返回401 Unauthorized
            throw new ArithmeticException("No token provided");
        }
        // 验证token是否有效
        final String userName = JwtTokenUtil.verifierJwtToken(token);
        String redisToken = belleJedisClient.get(RedisConstant.TOKEN_PREFIX + userName);
        if (StringUtils.isEmpty(redisToken)) {
            // 有token 但是token失效了
            throw new ArithmeticException("Token is invalid");
        }
        return true;
    }
}

觉得有用的话点个赞 👍🏻 呗。

❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

相关推荐
杜杜的man1 分钟前
【go从零单排】go语言中的指针
开发语言·后端·golang
测开小菜鸟2 分钟前
使用python向钉钉群聊发送消息
java·python·钉钉
P.H. Infinity1 小时前
【RabbitMQ】04-发送者可靠性
java·rabbitmq·java-rabbitmq
生命几十年3万天1 小时前
java的threadlocal为何内存泄漏
java
caridle1 小时前
教程:使用 InterBase Express 访问数据库(五):TIBTransaction
java·数据库·express
^velpro^1 小时前
数据库连接池的创建
java·开发语言·数据库
苹果醋31 小时前
Java8->Java19的初步探索
java·运维·spring boot·mysql·nginx
秋の花1 小时前
【JAVA基础】Java集合基础
java·开发语言·windows
小松学前端2 小时前
第六章 7.0 LinkList
java·开发语言·网络
Wx-bishekaifayuan2 小时前
django电商易购系统-计算机设计毕业源码61059
java·spring boot·spring·spring cloud·django·sqlite·guava