JWT工具类
创建Token的2种方式
private static final String jwtToken = "12345Lum!@#$%"; //密钥
public static String createToken(Long userId){
Map<String, Object> claims = new HashMap<>();
claims.put("userId",userId);
JwtBuilder jwtBuilder = Jwts.builder()
.signWith(SignatureAlgorithm.HS256,jwtToken) //签发算法,密钥为jwtToken
.setClaims(claims) //body数据,唯一,自行设置
.setIssuedAt(new Date()) //设置签发时间
.setExpiration(new Date(System.currentTimeMillis() + 24 * 60 * 60 *1000)); //一天都有效时间
return jwtBuilder.compact();
}
public static String genToken(String userId, String sign) {
return JWT.create()
.withHeader(map) //可以不设定,就是使用默认的
.withClaim("userId",20)//payload //自定义用户名
.withAudience(userId) // 将 user id 保存到 token 里面,作为载荷
.withExpiresAt(DateUtil.offsetHour(new Date(), 2)) // 2小时后token过期
.sign(Algorithm.HMAC256(sign)); // 以 password 作为 token 的密钥
}
组成
JWT 标准的 Token 由三个部分组成:header.payload.signature:
- header(头部)
- payload(数据)
- signature(签名)
头部的默认
map.put("typ", "JWT");
map.put("alg", "HS512");