一起学习Spring boot 2.1.X | 第十六篇:JSON Web Tokens

1.POM依赖

<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactId>
    <version>0.9.0</version>
</dependency>

2.JwtUti.java

import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;

import java.util.Date;

public class JWTUtil {

    private final static String KEY = "myScrect";//签名秘钥

    private final static long TOKEN_EXP = 1000 * 60 * 10;//过期时间,测试使用十分钟

    //生成Token
    public static String getToken(String Uniqueness) {
        return Jwts.builder().setSubject(Uniqueness).signWith(SignatureAlgorithm.HS512, KEY).compact();
    }

    //解析Token
    public static String analysisToken(String Token) {
        System.out.println(Jwts.parser().setSigningKey(KEY).parseClaimsJws(Token).getBody());
        return Jwts.parser().setSigningKey(KEY).parseClaimsJws(Token).getBody().getSubject();
    }

    //判断是否为空
    public static boolean isTokenExpired(String Token) {
        return Jwts.parser().setSigningKey(KEY).parseClaimsJws(Token).getBody().getExpiration().before(new Date(System.currentTimeMillis()));
    }

}

3.测试

//唯一ID
String Token = JWTUtil.getToken(userid);
System.out.println(JWTUtil.getToken(userid));
System.out.println(Token);
//解析Token
String user = JWTUtil.analysisToken(Token);


@RequestMapping("/B")
    public String B(String Token){
        String user = null;
        try {
            System.out.println(JWTUtil.isTokenExpired(Token));
            if (JWTUtil.isTokenExpired(Token)){
                return "'flag':'0'";
            }
            user = JWTUtil.analysisToken(Token);

        }catch (Exception e){
            System.out.println(e.getMessage());
        }
        return user;
    }

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值