java-jwt工具类

utils

package com.sise.JWT;

import java.text.SimpleDateFormat;

import java.util.Base64;

import java.util.Date;

import java.util.HashMap;

import java.util.Map;

import io.jsonwebtoken.*;

import io.jsonwebtoken.security.Keys;

import org.apache.commons.lang3.StringUtils;

import javax.crypto.SecretKey;

/**

  • @author:Tlimited

*/

public class JwtUtil {

private static final long EXPIRE = 60 * 1000; //过期时间

public static final SecretKey key = Keys.secretKeyFor(SignatureAlgorithm.HS256);//密钥,动态生成的密钥

/**

  • 生成token

  • @param claims 要传送消息map

  • @return

*/

public static String generate(Map<String,Object> claims) {

Date nowDate = new Date();

//过期时间,设定为一分钟

Date expireDate = new Date(System.currentTimeMillis() + EXPIRE);

//头部信息,可有可无

Map<String, Object> header = new HashMap<>(2);

header.put(“typ”, “jwt”);

//更强的密钥,JDK11起才能用

// KeyPair keyPair = Keys.keyPairFor(SignatureAlgorithm.RS256);

// PrivateKey key1 = keyPair.getPrivate(); // 私钥

//PublicKey key2 = keyPair.getPublic(); //公钥

return Jwts.builder().setHeader(header)

// .setSubject(“weimi”)//主题

// .setIssuer(“weimi”) //发送方

.setClaims(claims) //自定义claims

.setIssuedAt(nowDate)//当前时间

.setExpiration(expireDate) //过期时间

.signWith(key)//签名算法和key

.compact();

}

/**

  • 生成token

  • @param header 传入头部信息map

  • @param claims 要传送消息map

  • @return

*/

public static String generate( Map<String, Object> header,Map<String,Object> claims) {

Date nowDate = new Date();

//过期时间,设定为一分钟

Date expireDate = new Date(System.currentTimeMillis() + EXPIRE);

return Jwts.builder().setHeader(header)

// .setSubject(“weimi”)//主题

// .setIssuer(“weimi”) //发送方

.setClaims(claims) //自定义claims

.setIssuedAt(nowDate)//当前时间

.setExpiration(expireDate) //过期时间

.signWith(key)//签名算法和key

.compact();

}

/**

  • 校验是不是jwt签名

  • @param token

  • @return

*/

public static boolean isSigned(String token){

return Jwts.parser()

.setSigningKey(key)

.isSigned(token);

}

/**

  • 校验签名是否正确

  • @param token

  • @return

*/

public static boolean verify(String token){

try {

Jwts.parser()

.setSigningKey(key)

.parseClaimsJws(token);

return true;

}catc

必看视频!获取2024年最新Java开发全套学习资料 备注Java

h (JwtException e){

System.out.println(e.getMessage());

return false;

}

}

/**

  • 获取payload 部分内容(即要传的信息)

  • 使用方法:如获取userId:getClaim(token).get(“userId”);

  • @param token

  • @return

*/

public static Claims getClaim(String token) {

Claims claims = null;

try {

claims = Jwts.parser()

.setSigningKey(key)

.parseClaimsJws(token)

.getBody();

} catch (Exception e) {

e.printStackTrace();

}

return claims;

}

/**

  • 获取头部信息map

  • 使用方法 : getHeader(token).get(“alg”);

  • @param token

  • @return

*/

public static JwsHeader getHeader(String token) {

JwsHeader header = null;

try {

header = Jwts.parser()

.setSigningKey(key)

.parseClaimsJws(token)

.getHeader();

} catch (Exception e) {

e.printStackTrace();

}

return header;

}

/**

  • 获取jwt发布时间

*/

public static Date getIssuedAt(String token) {

return getClaim(token).getIssuedAt();

}

/**

  • 获取jwt失效时间

*/

public static Date getExpiration(String token) {

return getClaim(token).getExpiration();

}

/**

  • 验证token是否失效

  • @param token

  • @return true:过期 false:没过期

*/

public static boolean isExpired(String token) {

try {

final Date expiration = getExpiration(token);

return expiration.before(new Date());

} catch (ExpiredJwtException expiredJwtException) {

return true;

}

}

/**

  • 直接Base64解密获取header内容

  • @param token

  • @return

*/

public static String getHeaderByBase64(String token){

String header = null;

最后

} catch (ExpiredJwtException expiredJwtException) {

return true;

}

}

/**

  • 直接Base64解密获取header内容

  • @param token

  • @return

*/

public static String getHeaderByBase64(String token){

String header = null;

最后

[外链图片转存中…(img-59RcTgcF-1716449419637)]

[外链图片转存中…(img-B1QBvhxf-1716449419637)]

[外链图片转存中…(img-XqBz9Eqt-1716449419638)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值