springboot 定時任務 session報錯問題


一、自定義類 LocalVariable

package com.lh.mes.base.thread;

import java.util.Optional;

public class LocalVariable {

    private LocalVariable() {

    }

    private static final ThreadLocal<String> PRINCIPAL_ID = new ThreadLocal<>();

    /**
     * 添加用戶id
     * @param principalId 用戶id
     */
    public static void setPrincipalId(String principalId) {
        PRINCIPAL_ID.set(principalId);
    }

    /**
     * 獲取用戶id
     * @return  用戶id
     */
    public static String getPrincipalId() {
        return PRINCIPAL_ID.get();
    }

    public static Optional<String> getPrincipalIdOptional() {
        return Optional.ofNullable(getPrincipalId());
    }
}

二、攔截器保存想要保存的值

package com.lh.mes.base.interceptor;

import com.lh.mes.base.annotation.Authorization;
import com.lh.mes.base.constant.AuthorizationConstants;
import com.lh.mes.base.thread.LocalVariable;
import com.lh.mes.base.utils.TokenUtil;
import io.jsonwebtoken.Claims;
import io.jsonwebtoken.ExpiredJwtException;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;
import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;
import springfox.documentation.swagger.web.ApiResourceController;
import springfox.documentation.swagger2.web.Swagger2Controller;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.lang.reflect.Method;

/**
 * token 攔截器
 * @author Niles
 */
@Slf4j
@Component
public class AccessTokenInterceptor implements HandlerInterceptor {

    /** redis 數據庫操作模板類*/
    @Autowired
    private RedisTemplate<String, String> redisTemplate;

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
        //如果不是映射到方法直接通過
        if (!(handler instanceof HandlerMethod)
                || ((HandlerMethod) handler).getBean() instanceof ApiResourceController
                || ((HandlerMethod) handler).getBean() instanceof Swagger2Controller) {
            return true;
        }
        HandlerMethod handlerMethod = (HandlerMethod) handler;
        Method method = handlerMethod.getMethod();
        Authorization authorization = method.getAnnotation(Authorization.class);
        if (authorization != null && !authorization.required()) {
            //過濾不攔截的方法
            return true;
        }
        //從header中得到token
        String token = request.getHeader(AuthorizationConstants.AUTHORIZATION);
        if (!StringUtils.hasText(token)) {
            response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
            return false;
        }
        Claims claims;
        try {
            claims = TokenUtil.parseJWT(token);
        } catch (ExpiredJwtException expiredJwtException) {
            response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
            log.warn("token 過期了");
            return false;
        } catch (Exception exception) {
            response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
            log.warn("無效 token");
            return false;
        }
        String principalId = claims.getId();
        if (!redisTemplate.opsForSet().isMember(AuthorizationConstants.REDIS_TOKEN_KEY + principalId, token)) {
            response.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
            log.info("用戶不存在或已失效,請重新登錄");
            return false;
        }
        LocalVariable.setPrincipalId(principalId);
        return true;
    }

}

三、獲取保存的值

    /**
     * 獲取當前登錄用戶id
     *
     * @return 當前登錄用戶id
     */
    @Override
    public String getCurrentPrincipalId() {
        return LocalVariable.getPrincipalId();
    }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM