JWT令牌的生成与校验-javaSpringBoot

引入依赖

在pom文件中添加如下代码引入依赖

        <dependency>    
            <groupId>com.auth0</groupId>
            <artifactId>java-jwt</artifactId>
            <version>4.4.0</version>
        </dependency>

 生成令牌

        Map<String,Object> map = new HashMap<>();
        map.put("id","1");
        map.put("username","张三");
//        生成jwt
        String token = JWT.create()
                //添加载荷
                .withClaim("user",map)
                //过期时间
                .withExpiresAt(new Date(System.currentTimeMillis()+1000*60*60*24))
                //指定加密算法并配置密钥
                .sign(Algorithm.HMAC256("root"));
//        输出生成的令牌
        System.out.println(token);

解析令牌 

        String Token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9." +
                "eyJ1c2VyIjp7ImlkIjoiMSIsInVzZXJuYW1lIjoi5byg5LiJIn0sImV4cCI6MTcyNDEzOTAyNH0." +
                "GRpk4FEeT0Ku0ZC4fIZSwDl8msgytxa61oq8iSe_Fp8";
        //获取一个HMAC256加密算法的解析器,并设置解析密钥
        JWTVerifier jwtVerifier = JWT.require(Algorithm.HMAC256("root")).build();
        //使用生成的解析器解析token获得jwt对象
        DecodedJWT decodedJWT = jwtVerifier.verify(Token);
        //通过解析后的jwt对象中的getClaims获取载荷
        Map<String, Claim> claims = decodedJWT.getClaims();

        System.out.println(claims.get("user"));

  • 7
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以帮助你生成一个JWT生成校验的代码。 首先,你需要安装 JSON Web Token(JWT)的依赖。在 Node.js 中,你可以使用以下命令安装它: ``` npm install jsonwebtoken ``` 然后,你可以使用以下代码生成一个JWT: ```javascript const jwt = require('jsonwebtoken'); const payload = { // 这里是 JWT 里面的 payload 数据 userId: 123, username: 'john.doe', }; const secret = 'your-secret-key'; const token = jwt.sign(payload, secret, { expiresIn: '1h' }); console.log(token); ``` 在这个代码中,我们首先定义了一个 `payload` 对象,里面包含了一些与用户有关的数据。然后,我们定义了一个 `secret`,用于加密 JWT。 最后,我们使用 `jwt.sign` 方法生成 JWT,并将其打印到控制台上。 生成 JWT 后,你还可以根据需要对其进行校验。以下是一个简单的校验代码: ```javascript const jwt = require('jsonwebtoken'); const token = 'your-jwt-token'; const secret = 'your-secret-key'; try { const decoded = jwt.verify(token, secret); console.log(decoded); } catch (e) { console.error(e); } ``` 在这个代码中,我们首先定义了一个 `token`,它是我们之前生成JWT。然后,我们使用 `jwt.verify` 方法对其进行校验。 如果校验成功,`jwt.verify` 方法将返回 JWT 的 `payload`,你可以在代码中进一步处理 `payload`。否则,它将抛出一个异常,您可以在 catch 语句中捕获并处理它。 希望这些代码可以帮助您解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值