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:
  }
}
相关推荐
毕设源码-朱学姐12 分钟前
【开题答辩全过程】以 基于JavaWeb的网上家具商城设计与实现为例,包含答辩的问题和答案
java
C雨后彩虹2 小时前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
java1234_小锋3 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试
2501_944525543 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐3 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法
Filotimo_3 小时前
Tomcat的概念
java·tomcat
索荣荣4 小时前
Java Session 全面指南:原理、应用与实践(含 Spring Boot 实战)
java·spring boot·后端
Amumu121384 小时前
Vue Router(二)
java·前端
念越4 小时前
数据结构:栈堆
java·开发语言·数据结构