<dependency>
<groupId>com.auth0</groupId>
<artifactId>java-jwt</artifactId>
<version>3.4.0</version>
</dependency>
工具类
public class TokenUtils {
//设置过期时间
// private static final long EXPIRE_DATE=1000 ;
private static final long EXPIRE_DATE=30*60*1000;
//token秘钥
private static final String TOKEN_SECRET = "token";
public static String token (String userNo,String password){
String token = "";
try {
//过期时间
Date date = new Date(System.currentTimeMillis()+EXPIRE_DATE);
//秘钥及加密算法
Algorithm algorithm = Algorithm.HMAC256(TOKEN_SECRET);
//设置头部信息
Map<String,Object> header = new HashMap<>();
header.put("typ","JWT");
header.put("alg","HS256");
//携带username,password信息,生成签名
token = JWT.create()
.withHeader(header)
.withClaim("userNo",userNo)
.withExpiresAt(date)
.sign(algorithm);
}catch (Exception e){
e.printStackTrace();
return null;
}
return token;
}
/**
* @desc 验证token,通过返回true
* @params [token]需要校验的串
**/
public static boolean verify(String token){
try {
Algorithm algorithm = Algorithm.HMAC256(TOKEN_SECRET);
JWTVerifier verifier = JWT.require(algorithm).build();
DecodedJWT jwt = verifier.verify(token);
return true;
}catch (Exception e){
e.printStackTrace();
return false;
}
}
/**
* 获取token中的用户编号
* @Author: yjw 2022-05-11
* @return:
*/
public static String getTokenUserNo(String token){
return JWT.decode(token).getClaim("userNo").asString();
}
测试main
public static void main(String[] args) throws InterruptedException {
String userNo = "qweasdf123123";
String token = token(userNo ,"");
System.out.println("生成token>>"+token);
TimeUnit.SECONDS.sleep(3);
boolean b = verify(token);
System.out.println("校验 >>"+ b);
String d = getTokenUserNo(token);
System.out.println("userNo >>"+d);
}`