JWT 简单使用

依赖导入

<dependency>
    <groupId>com.auth0</groupId>
    <artifactId>java-jwt</artifactId>
    <version>3.8.1</version>
</dependency>
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactId>
    <version>0.9.1</version>
</dependency>

概念

JWT的本质就是一个字符串,它是将用户信息保存到一个Json字符串中,然后进行编码后得到一个 Token并且该字符串还带有签名信息,接收后可以校验是否被篡改,所以可以用于在各方之间安全地将信息作为JSON对象传输

使用

创建Token

// 默认过期时间为 3600 分钟
private static final long EXPIPE_TIME = 3600 * 60 * 1000;

// 加密 Token 的密钥名称
private static final String SECRET = "MiYao";

/**
 * 生成签名,五分钟后过期
 * 并在 token 创建时,将 userID 也存放至 Token 内
 * @param userId
 * @return
 */
public static String sign(String userId) {
    try {
        Date date = new Date(System.currentTimeMillis() + EXPIRE_TIME);
        // JWT 通过 Algorithm.HMAC256(SECRET) 携带的密钥进行加密 
        Algorithm algorithm = Algorithm.HMAC256(SECRET);
        return JWT.create()
                // 将 user id 保存到 token 里面
                .withAudience(userId)
                // 五分钟后token过期
                .withExpiresAt(date)
                // 添加密钥加密条件
                .sign(algorithm);
    } catch (Exception e) {
        return null;
    }
}




/**
 * 根据token获取 userId
 * @param token
 * @return
 */
public static String getUserId(String token) {
    try {
        // 获取创建token时放置与token内的userID
        String userId = JWT.decode(token).getAudience().get(0);
        return userId;
    } catch (JWTDecodeException e) {
        return null;
    }
}

校检 Token

// 加密 Token 的密钥名称
private static final String SECRET = "MiYao";

/**
 * 校验token
 * @param token
 * @return
 */
public static boolean checkSign(String token) {
    try {
        Algorithm algorithm = Algorithm.HMAC256(SECRET);
        // 通过密钥进行解密
        JWTVerifier verifier = JWT.require(algorithm).build();
        /**
         * 通过 verifier.verify() 方法检验 token,如果token不符合则抛出异常
         */
        DecodedJWT jwt = verifier.verify(token);
        return true;
    } catch (JWTVerificationException exception) {
        return false;
    }
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值