WebMvcConfigurationSupport 注册自定义拦截器 Java SpringBoot

WebMvcConfigurationSupport 注册自定义拦截器 Java SpringBoot

说明

定义拦截器

拦截器(Interceptor)类,用于在处理请求之前进行一些操作。

  • 实现方式,让类实现HandlerInterceptor
    1. preHandle方法中进行请求拦截的逻辑操作。
    2. 首先判断拦截到的处理器(handler)是否为Controller的方法,如果不是,则直接放行。
java 复制代码
@Component
@Slf4j
public class RedisTokenAdminInterceptor implements HandlerInterceptor{}

判断当前请求是不是动态方法(是不是controller层的内容),如果是则进行拦截。

java 复制代码
public boolean preHandle(@NotNull HttpServletRequest request, @NotNull HttpServletResponse response, @NotNull Object handler) throws IOException {
    // 判断当前兰街道的是Controller的方法还是其它资源 拦截到的不是动态方法,直接放行
    if (!(handler instanceof HandlerMethod)) return true;

    // 1. 从请求头中获取令牌
    String token = request.getHeader(redisTokenProperties.getAdminTokenName());
    log.info("jwt校验:{}", token);
    if (token == null) {
        InterceptorUtil.unLoginInterceptor(response);
        return false;
    }

    try {
        Object empId = redisTemplate.opsForValue().get(token);
        log.info("当前员工ID:{}", empId);
        if (empId == null) {
            InterceptorUtil.customLoginInterceptor(response, MessageConstant.USER_TOKEN_OUT_OF_DATE, "");
            return false;
        }
        // 3. 通过放行
        BaseContext.setUserId(Long.valueOf(empId.toString()));
        return true;
    } catch (Exception exception) {
        InterceptorUtil.customLoginInterceptor(response, exception.getMessage(), "");
        return false;
    }
}

配置类

让配置类继承WebMvcConfigurationSupport

java 复制代码
@Configuration
@Slf4j
public class WebMvcConfiguration extends WebMvcConfigurationSupport{}

在配置类中注入拦截器RedisTokenAdminInterceptor

java 复制代码
@Configuration
@Slf4j
public class WebMvcConfiguration extends WebMvcConfigurationSupport {
    @Autowired
    RedisTokenAdminInterceptor adminInterceptor;

    /**
     * 注册自定义拦截器
     *
     * @param registry InterceptorRegistry
     */
    protected void addInterceptors(InterceptorRegistry registry) {
        log.info("开始注册自定义拦截器...");
        registry.addInterceptor(adminInterceptor).addPathPatterns("/admin/**")
                .excludePathPatterns("/admin/employee/login");
    }
}

添加需要拦截的

相关推荐
txinyu的博客几秒前
Reactor 模型全解析
java·linux·开发语言·c++
IMPYLH几秒前
Lua 的 Package 模块
java·开发语言·笔记·后端·junit·游戏引擎·lua
sunnyday04261 分钟前
API安全防护:签名验证与数据加密最佳实践
java·spring boot·后端·安全
间彧2 分钟前
java类的生命周期及注意事项
java
Ulyanov4 分钟前
Python射击游戏开发实战:从系统架构到高级编程技巧
开发语言·前端·python·系统架构·tkinter·gui开发
会飞的小新4 分钟前
Java 应用程序已被安全阻止 —— 原因分析与解决方案
java·安全
点云SLAM5 分钟前
C++依赖注入(Dependency Injection DI)vs单例设计模式(Singleton)
开发语言·c++·单例模式·设计模式·日志配置·依赖注入di·大项目系统
Geoking.8 分钟前
【设计模式】责任链模式(Chain of Responsibility)详解
java·设计模式·责任链模式
Hello.Reader8 分钟前
连接四元组它为什么重要,以及它和端口复用(SO_REUSEPORT)的关系(Go 实战)
开发语言·后端·golang
sunnyday042610 分钟前
Spring AOP 实现日志切面记录功能详解
java·后端·spring