spring boot JWT令牌工具类

import io.jsonwebtoken.Claims;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import java.util.Date;
import java.util.Map;


public class JwtUtils {
    private static String signKey = "muyan";//key
    private static long expire = 1000 * 60 * 60 * 24; //一天
    /***
     * 生成JWT令牌
     * @param data 要存储的数据 String字符串,可以是JSON数据
     * @return
     */
    public static String generateJwt(String data){
        String jwt = Jwts.builder()
                .setSubject(data)
                .signWith(SignatureAlgorithm.HS256, signKey)
                .setExpiration(new Date(System.currentTimeMillis() + expire))
                .compact();
        return jwt;
    }

    /***
     * 生成JWT令牌Map
     * @param claims 要存储的数据 Map集合
     * @return
     */
    public static String generateJwtMap(Map<String, Object> claims){
        String jwt = Jwts.builder()
                .addClaims(claims)
                .signWith(SignatureAlgorithm.HS256, signKey)
                .setExpiration(new Date(System.currentTimeMillis() + expire))
                .compact();
        return jwt;
    }
    /**
     * 解析JWT令牌
     * @param jwt JWT令牌
     * @return
     */
    public static Claims parseJWT(String jwt){
        Claims claims = Jwts.parser()
                .setSigningKey(signKey)
                .parseClaimsJws(jwt)
                .getBody();
        return claims;
    }
}
posted @ 2023-10-12 13:41  大理鱼儿  阅读(85)  评论(0)    收藏  举报  来源