JWT令牌快速入门

JWT令牌快速入门

  • 全称JSON Web Token:是一种简洁的、自包含的格式,用于在通信双方以json数据格式安全的传输信息。由于数字签名的存在,这些信息基本可靠。
  • 组成
    • 第一部分Header(头),记录令牌的类型、签名算法等。
      例如:{"alg": "HS256", "typ": "JWT"}
    • 第二部分Payload(有效载荷),携带一些自定义信息,默认信息等。
      例如:{"id":1,"name": "xiaoChenCoding"}
    • 第三部分Signature(签名),防止Token被篡改,确保安全性。融入HeaderPayload和指定密匙,通过指定签名算法计算而来。
  • JWT官网

接下来我将帮助你快速入门JWT并实现一个员工登录接口并通过JWT令牌校验登录的合法性

入门教程

第一步

  • pom文件引入JWT依赖
<!--Java8及以下引入jjwt依赖即可-->
<!--JWT令牌-->
<dependency>
    <groupId>io.jsonwebtoken</groupId>
    <artifactId>jjwt</artifactId>
    <version>0.9.1</version>
</dependency>
<!--如果是Java8以上版本还需要添加以下依赖:
因为 javax.xml.bind.DatatypeConverter 类已被弃用并从 Java SE 9 中移除。-->
<dependency>
    <groupId>javax.xml.bind</groupId>
    <artifactId>jaxb-api</artifactId>
    <version>2.3.1</version>
</dependency>
<!--如果您使用的是 Java 11 或更高版本,则还需要添加 JAXB Runtime 依赖项-->
<dependency>
    <groupId>javax.xml.bind</groupId>
    <artifactId>jaxb-runtime</artifactId>
    <version>2.3.3</version>
</dependency>

第二步

  • 编写JWT生成类
@SpringBootTest
public class JWTTest {
	/**
     * 生成JWT令牌
     */
    @Test
    public void testGenJwt() {

        // 定义载荷,即存放在JWT中的信息
        HashMap<String, Object> claims = new HashMap<>();
        claims.put("id",1);
        claims.put("name","小陈Coding");

        String jwt = Jwts.builder()
                .signWith(SignatureAlgorithm.HS256, "xiaoChenCoding")//添加签名算法和密匙
                .setClaims(claims)//添加自定义内容(载荷)
                .setExpiration(new Date(System.currentTimeMillis() + 60 * 1000 * 60 * 24))//设置有效期为1天
                .compact();
        System.out.println(jwt);
    }
}

控制台输出:eyJhbGciOiJIUzI1NiJ9.eyJuYW1lIjoi5bCP6ZmIQ29kaW5nIiwiaWQiOjEsImV4cCI6MTcxMTczMzQ3M30.E-I6d5A_ClPOMV7HZZg4kiiyNGBvEH5-qCOEmocj9Gs

  • 关于签名算法有很多种可以去官网查看
    在这里插入图片描述

第三步

  • 编写JWT解析类
@Test
    public void testParseJwt() {
       String jwt = "eyJhbGciOiJIUzI1NiJ9.eyJuYW1lIjoi5bCP6ZmIQ29kaW5nIiwiaWQiOjEsImV4cCI6MTcxMTczMzQ3M30.E-I6d5A_ClPOMV7HZZg4kiiyNGBvEH5-qCOEmocj9Gs";
       Claims claims = Jwts.parser()
               .setSigningKey("xiaoChenCoding")//设置解析的密匙
               .parseClaimsJws(jwt)//需要解析的jwt令牌
               .getBody();
        System.out.println(claims);
   }

控制台输出:{name=小陈Coding, id=1, exp=1711733473}

  • exp是过期时间

实战教程

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值