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:
  }
}
相关推荐
宠友信息13 小时前
多端数据互通场景下Spring Boot仿小红书源码结构设计
数据库·spring boot·redis·缓存·架构
不会c+13 小时前
02-SpringBoot配置文件
java·spring boot·后端
AI 大模型学习不踩坑13 小时前
OpenClaw 完整教程:从安装到使用(官方脚本版)
java·人工智能·神经网络·机器学习·计算机视觉·自然语言处理·openclaw
Listen·Rain14 小时前
数据库流式查询
java·数据库
彦为君14 小时前
算法思维与经典智力题
java·前端·redis·算法
翔云 OCR API14 小时前
慧视扫描王-财务少加班
java·自动化
雨辰AI14 小时前
生产级实战:人大金仓 V9 标准化运维手册(日常巡检 + 监控告警 + 应急处置)
java·运维·数据库·后端
我是一颗柠檬14 小时前
【Java项目技术亮点】覆盖索引与索引下推优化
android·java·开发语言
云道轩14 小时前
比较IBM Transformation Advisor 和WebSphere Application Server Migration Toolkit
java·jakarta ee·open liberty·应用迁移
2601_9624408415 小时前
计算机毕业设计之健身房管理系统的设计与实现
java·开发语言·课程设计·旅游·宠物