SpringBoot 集成 JWT 生成Token

  1. 导入依赖
<!-- JWT-->
            <dependency>
                <groupId>io.jsonwebtoken</groupId>
                <artifactId>jjwt</artifactId>
                <version>0.9.1</version>
            </dependency>
  1. 自定义JWT工具类
package com.sdmc.open.api.util;

import io.jsonwebtoken.Claims;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.stereotype.Component;
import org.springframework.util.StringUtils;

import java.util.Calendar;
import java.util.Date;
import java.util.Map;

/**
 * @author: Barry
 * @projectName: tms-modularization
 * @title: JWTUtils
 * @description: TODO
 * @date: 2021/3/6 16:46
 */
@RefreshScope
@Component
public class JwtTokenUtil {

    private static final String CLAIM_KEY_SUBJECT = "sub";
    private static final String CLAIM_KEY_CREATED = "created";

    @Value("${jwt.secret}")
    private String secret;

    @Value("${jwt.expiration}")
    private Long expiration;

    @Value("${jwt.tokenHead}")
    private String tokenHead;

    /**
     * @description: 生成Token
     * @param: claims
     * @return: java.lang.String
     */
    public String generateToken(Map<String,Object> claims){
        return Jwts.builder().setClaims(claims)
                .setExpiration(new Date(System.currentTimeMillis() + expiration * 1000))
                .signWith(SignatureAlgorithm.HS512,secret)
                .compact();
    }

    /**
     * 解析token是否合法
     * @param jwt
     * @return
     */
    private String parseToken(String jwt) {
        return Jwts.parser()
                .setSigningKey(secret)
                .parseClaimsJws(jwt)
                .getBody()
                .getSubject();
    }

    /**
     * @description: 从Token中获取信息
     * @param: token
     * @return: io.jsonwebtoken.Claims
     */
    public Claims getClaimsFromToken(String token){
        return Jwts.parser().setSigningKey(secret).parseClaimsJws(token).getBody();
    }


    /**
     * @description: 验证Token
     * @param: token
     * @param: userDetails
     * @return: boolean
     */
    public boolean validateToken(String token){
        try {
            parseToken(token);
            if(isTokenExpired(token)){
                return false;
            }
        }catch (Exception e){
            return false;
        }
        return true;
    }

    /**
     * @description: 判断Token是否已经过期
     * @param: token
     * @return: boolean
     */
    private boolean isTokenExpired(String token){
        Date expiredDate = getExpiredDateFromToken(token);
        return expiredDate.before(new Date());
    }

    /**
     * @description: 获取过期时间
     * @param: token
     * @return: java.util.Date
     */
    public Date getExpiredDateFromToken(String token){
        return getClaimsFromToken(token).getExpiration();
    }


    /**
     * 当原来的token没过期时是可以刷新的
     *
     * @param oldToken 带tokenHead的token
     */
    public String refreshHeadToken(String oldToken) {
        if(StringUtils.isEmpty(oldToken)){
            return null;
        }
        String token = oldToken.substring(tokenHead.length());
        if(StringUtils.isEmpty(token)){
            return null;
        }
        //token校验不通过
        Claims claims = getClaimsFromToken(token);
        if(claims==null){
            return null;
        }
        //如果token已经过期,不支持刷新
        if(isTokenExpired(token)){
            return null;
        }
        //如果token在30分钟之内刚刷新过,返回原token
        if(tokenRefreshJustBefore(token,30*60)){
            return token;
        }else{
            claims.put(CLAIM_KEY_CREATED, new Date());
            return generateToken(claims);
        }
    }

    /**
     * 判断token在指定时间内是否刚刚刷新过
     * @param token 原token
     * @param time 指定时间(秒)
     */
    private boolean tokenRefreshJustBefore(String token, int time) {
        Claims claims = getClaimsFromToken(token);
        Date created = claims.get(CLAIM_KEY_CREATED, Date.class);
        Date refreshDate = new Date();
        //刷新时间在创建时间的指定时间内
        Calendar instance = Calendar.getInstance();
        instance.setTime(created);
        instance.add(Calendar.SECOND,time);
        if(refreshDate.after(created) && refreshDate.before(instance.getTime())){
            return true;
        }
        return false;
    }

}
  1. 更新配置文件
#JWT
jwt.secret=xvYnOL6Bp5xM/mQGF11gd7k1/dKfS8/J
jwt.expiration=6000
jwt.tokenHead=openApi
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值