JWT(JSON Web Token)入门

JWT简介

用于通信双方基于JSON数据格式安全的传输信息

组成:(使用Base64编码格式)

第一部分:Heade,记录令牌类型和签名算法,如:{"alg":"HS256","type":"JWT"}

第二部分:Payload:携带一些自定义信息、默认信息

第三部分:Signature,经密钥和算法对header、payload进行计算而来

使用JWT

导入坐标

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

生成JWT

public class TestJWT {

    @Test
    public void generateJWT(){
        //添加payload的数据
        Map<String,Object> claims = new HashMap<>();
        claims.put("id",1);
        claims.put("username","张三");
        //生产token字符串,secretKey为自定义密钥,ttlMillis是token到期时间
        String token = JWT.create()
            .withClaim("usr",claims)
            .withExpireAt(new Date(System.currentTimeMillis()+1000*60*60*12))
            .sign(Algorithm.HMAC256("sky"));

        System.out.println(token);
    }
}

验证JWT

@Test
public  void verifyJWT(){
    String token = "eyJhbGciOiJIUzI1NiJ9.eyJpZCI6MSwiZXhwIjozNDE2NDA1MzU3LCJ1c2VybmFtZSI6IuW8oOS4iSJ9.md7DfOvTgbqM8A2HUjJnLGl1QGXWznMnGiB4q8g0_FY";
    //JWT验证器
    JWTVerifier jwtVerifier = JWT.require(Algorithm.HMAC256("sky")).bilud();
    //验证token,返回解析后的JWT对象
    DecodedJWT decodedJWT = jwtVerifier.verify(token);
    //拿取payload数据
    Map<String,Claim> claims = decodedJWT.getClaims();
    System.out.println(claims.get("usr"));
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值