码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 这是JWT 简单使用


    JWT 是 Json Web Token的缩写

    JSON Web Tokens - jwt.ioJSON Web Token (JWT) is a compact URL-safe means of representing claims to be transferred between two parties. The claims in a JWT are encoded as a JSON object that is digitally signed using JSON Web Signature (JWS).https://jwt.io/

    JWT 的结构格式如下:

    xxxxx.yyyyy.zzzzz

    由三部分组成,每部分 用 点 分割

    第一部分:

    头部,记录 使用的 加密算法的类型

    第二部分:

    Body,记录一些额外信息

    第三部分:

    签名,用来校验 数据是否 被篡改

    OK,Java工具包如下,使用 jjwt 

    1. <dependency>
    2. <groupId>io.jsonwebtokengroupId>
    3. <artifactId>jjwtartifactId>
    4. <version>0.9.0version>
    5. dependency>

    OK,生成一个 JWT 步骤:

    确定 使用的加密算法,jjwt 工具包已经 给我们提供好了各种加密算法的枚举

    io.jsonwebtoken.SignatureAlgorithm

    确定 使用的秘钥

    SecretKey secretKey = new SecretKeySpec("秘钥字符串".getBytes(), "AES"); 

    构建Body部分,该部分 是一个 Map

    另外,可以构建 JWT 的创建时间 和 失效时间

    1. String jwtToken = Jwts.builder()
    2. .setClaims()
    3. .setIssuedAt()
    4. .signWith()
    5. .setExpiration()
    6. .compact();

     

    OK,解析 JWT

    使用和 生成 JWT 相同的 秘钥,因为 token中已经有 算法信息了,所以不用再设置算法。

    1. Claims claims = Jwts.parser()
    2. .setSigningKey()
    3. .parseClaimsJws()
    4. .getBody();

    解析获取到 Claims 对象,可以获取 body 中的数据。

    完整示例代码:

    1. // 生成token
    2. // 签名算法
    3. SignatureAlgorithm algorithm = SignatureAlgorithm.HS256;
    4. // 加密秘钥
    5. SecretKey secretKey = new SecretKeySpec("1234567890".getBytes(), "AES");
    6. // body部分
    7. Map body = new HashMap<>();
    8. body.put("userId", "0001");
    9. // 创建时间 和 实效时间
    10. long nowMillis = System.currentTimeMillis();
    11. long expMillis = nowMillis + 1000 * 60 * 1;
    12. Date iat = new Date(nowMillis);
    13. Date exp = new Date(expMillis);
    14. //生成jwt
    15. String jwtToken = Jwts.builder()
    16. .setClaims(body)
    17. .setIssuedAt(iat)
    18. .signWith(algorithm, secretKey)
    19. .setExpiration(exp)
    20. .compact();
    21. System.out.println(jwtToken);
    22. // Thread.sleep(1000 * 61 * 1);
    23. // 验证
    24. // 获取解密秘钥
    25. SecretKey key = new SecretKeySpec("1234567890".getBytes(), "AES");
    26. // 解析token
    27. Claims claims = Jwts.parser()
    28. .setSigningKey(key)
    29. .parseClaimsJws(jwtToken).getBody();
    30. Object userId = claims.get("userId");
    31. System.out.println("userId:" + userId);

    如果 token 失效 或者 加密 秘钥和解密秘钥 不同,都会解析失败。

    在需要权限校验的资源中,就可以 从请求信息中获取 jwt 来验证 权限。

  • 相关阅读:
    数据结构与算法之美学习笔记:52 | 算法实战(一):剖析Redis常用数据类型对应的数据结构
    Python 基础合集8:类的继承和多态
    特拉斯成为英国首相后 “英镑危机”的风险正在上升
    【17】c++设计模式——>原型模式
    从零开始学Spring Boot系列-集成MyBatis-Plus
    [论文精读|博士论文]面向文本数据的关系抽取关键技术研究
    英伟达 GPU 架构简史
    win11下安装golang
    深度学习笔记(51) 基础知识
    【计算机网络】物理层(一)
  • 原文地址:https://blog.csdn.net/htydowd/article/details/130850687
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号