JWT 使用入门(二)token有效期

配置与示例请先阅读第一篇:https://blog.csdn.net/qq_37534947/article/details/132066909

1.问题背景

  • 在具体的业务需求中,我们并不希望签发的token是永久生效的,所以我们可以为token添加一个过期时间。
  • 在Jwt的有效载荷中提供了默认7个字段,其中就包含过期时间,只需要在生成token的时候进行设置即可

2. token过期校验

2.1 生成token并设置有效时间1分钟

  • 生成token,设置有效时间1分钟,其中密钥设置为"itcast"

  • 注意签发时间需要小于过期时间

        public static String setJwt(){
            //这里为了方便测试,我们将过期时间设置为1分钟
            long now = System.currentTimeMillis();//当前时间
            long exp = now + 1000*60;//过期时间为1分钟
            JwtBuilder builder= Jwts.builder().setId("1111")
                    .setSubject("test")
                    .setIssuedAt(new Date())
                    .signWith(SignatureAlgorithm.HS256,"itcast")
                    .setExpiration(new Date(exp));
            String token =  builder.compact();
            return token;
        }
    

2.2 验证token

  • 把上面生成的token传进该函数里进行验证,其中密钥和上面一样,同为“itcast”
    public static void getJwt(String token) {
        String compactJws= token;
        Claims claims = Jwts.parser().setSigningKey("itcast").parseClaimsJws(compactJws).getBody();
        System.out.println("id:"+claims.getId());
        System.out.println("subject:"+claims.getSubject());
        SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");

        System.out.println("签发时间:"+sdf.format(claims.getIssuedAt()));
        System.out.println("过期时间:"+sdf.format(claims.getExpiration()));
        System.out.println("当前时间:"+sdf.format(new Date()) );
    }

2.2.1 在有效期时间内进行解析

  • 有效期进行解析,验证通过
    在这里插入图片描述

2.2.2 超过有效期时间内进行解析

  • 有效期进行解析,验证抛出过期异常
    在这里插入图片描述
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Studying_swz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值