JWT实现token

本文介绍了如何使用Java-JWT库生成和解析JSON Web Token(JWT)。首先,通过引入Auth0和jjwt的依赖,然后展示如何创建JWT,设置主题、过期时间和加密密码。接着,展示了如何解密JWT,获取并打印token中的数据。如果解密成功,则返回购物车列表接口,否则提示登录过期。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.引入依赖

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

2.利用Jwts生成token

  HashMap<String, Object> map = new HashMap<>();
                map.put("key1","value1");
                map.put("key2","value2");

JwtBuilder builder = Jwts.builder();
                String token = builder.setSubject(name) // 主题就是token中携带的数据
                        .setIssuedAt(new Date()) //设置token生成时间
                        .setId(users.get(0).getUserId().toString()) // 设置用户id位token id
                        .setClaims(map)
                        .setExpiration(new Date(System.currentTimeMillis() + 24 * 60 * 60 * 1000)) //设置过期时间
                        .signWith(SignatureAlgorithm.HS256, "zhang")  //设置加密方式和密码
                        .compact();

3.利用Jwts解密token

 try {
            JwtParser parser = Jwts.parser();
            parser.setSigningKey("zhang");  //设置解密密钥

            Jws<Claims> claimsJws = parser.parseClaimsJws(token);
            Claims body = claimsJws.getBody();
            String subject = body.getSubject();
            String key1 = body.get("key1", String.class);
            System.out.println("key1 = " + key1);
            System.out.println("subject = " + subject);

            // token 校验成功
            System.out.println("购物车列表接口 ");
            return ResultVo.ok();
        } catch (Exception e) {
            return ResultVo.error().message("登录过期,请重新登陆");

        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值