Spring Boot2.x.x全局拦截器

Spring Boot2.x.x全局token拦截器

Result 自定义封装请看另外的文章 Result封装

TokenInterceptorHandler.java

java 复制代码
package com.sky.handler;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.sky.result.Result;
import com.sky.utils.RedisUtils;
import lombok.extern.slf4j.Slf4j;
import org.springframework.http.HttpStatus;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.HandlerInterceptor;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@Slf4j
@Component
public class TokenInterceptorHandler implements HandlerInterceptor {

  private static final ObjectMapper objectMapper = new ObjectMapper();

  @Resource
  private RedisUtils redisUtils;

  private boolean writeJson(HttpServletResponse response, Result<?> result) throws Exception {
    response.setStatus(HttpStatus.UNAUTHORIZED.value());
    response.setContentType("application/json;charset=UTF-8");
    response.getWriter().write(objectMapper.writeValueAsString(result));
    return false;
  }

  @Override
  public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {

    String token = request.getHeader("Authorization");
    return true; // 接全部接口不做检验 如果需要检验接口 把下面注释的放开
//    // 如果请求不需要登录,可在这里设置白名单
//    String uri = request.getRequestURI();
//    if (uri.startsWith("/public") || uri.equals("/login")) {
//      return true;
//    }

//    if (token == null || token.isEmpty()) {
//      return writeJson(response, Result.unauthorized("未登录"));
//    }
//
//    String key = redisUtils.getRedisName() + token;
//    String userJson = (String) redisUtils.get(key);
//    if (userJson == null) {
//      return writeJson(response, Result.unauthorized("登录已过期"));
//    }
//
//    // 可在这里把用户信息放入 request,方便 Controller 使用
//    request.setAttribute("userInfo", userJson);
//
//    return true; // token 校验通过
  }
}

WebConfig.java

java 复制代码
package com.ruoyi.sky.config;

import com.ruoyi.sky.handler.TokenInterceptorHandler;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import java.io.Serializable;

//@Configuration // 配置类通常使用@Configuration注解进行标记,表示该类是一个配置类
@Configuration
public class WebConfig implements WebMvcConfigurer {
  private final TokenInterceptorHandler tokenInterceptorHandler;

  @Autowired
  public WebConfig(TokenInterceptorHandler tokenInterceptorHandler) {
    this.tokenInterceptorHandler = tokenInterceptorHandler;
  }

/*
	addPathPatterns("/**") 表示所有路径都会进入拦截器。
	excludePathPatterns(...) 表示这些路径不拦截。
*/
  @Override
  public void addInterceptors(InterceptorRegistry registry) {
    registry.addInterceptor(tokenInterceptorHandler)
        .addPathPatterns("/**")
        .excludePathPatterns(
            "/admin/employee/login",
            "/logout",
            "/public/**",
            "/swagger-ui/**",
            "/v2/api-docs",
            "/webjars/**"
        );
  }
}

RedisUtils.java 封装

java 复制代码
package com.sky.utils;

import com.sky.constant.RedisConstant;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;

import java.util.concurrent.TimeUnit;

@Component
public class RedisUtils {
  @Autowired
  private RedisTemplate redisTemplate;

  /**
   * 写入缓存(默认不过期)
   */
  public void set(String key, Object value) {
    redisTemplate.opsForValue().set(key, value);
  }

  /**
   * 写入缓存,并设置过期时间(单位:秒)
   */
  public void set(String key, Object value, long timeoutSeconds) {
    redisTemplate.opsForValue().set(key, value, timeoutSeconds, TimeUnit.SECONDS);
  }

  /**
   * 获取缓存
   */
  public Object get(String key) {
    return redisTemplate.opsForValue().get(key);
  }

  /**
   * 删除缓存
   */
  public void delete(String key) {
    redisTemplate.delete(key);
  }

  /**
   * 判断 key 是否存在
   */
  public boolean exists(String key) {
    return Boolean.TRUE.equals(redisTemplate.hasKey(key));
  }

  public String getRedisName() {
    return RedisConstant.REDIS_KEY; // 返回的是列如 login:user:
  }
}
相关推荐
上不如老下不如小17 分钟前
2025年第七届全国高校计算机能力挑战赛初赛 Java组 编程题汇总
java·计算机能力挑战赛
泉城老铁33 分钟前
Springboot对接mqtt
java·spring boot·后端
源码_V_saaskw37 分钟前
JAVA国际版同城跑腿源码快递代取帮买帮送同城服务源码支持Android+IOS+H5
android·java·ios·微信小程序
TT哇42 分钟前
消息推送机制——WebSocket
java·网络·websocket·网络协议
镜花水月linyi1 小时前
ConcurrentHashMap 深入解析:从0到1彻底掌握(1.3万字)
java·后端
极客Bob1 小时前
Java 集合操作完整清单(Java 8+ Stream API)
java
雨中飘荡的记忆1 小时前
Javassist实战指南
java
uhakadotcom1 小时前
Loguru 全面教程:常用 API 串联与实战指南
后端·面试·github
Knight_AL1 小时前
JWT 无状态认证深度解析:原理、优势
java·jwt