栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

快速入门JWT和简单应用

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

快速入门JWT和简单应用



数据格式是这样的 header.payload.signature

• alg: 声明加密的算法
• typ: 声明类型


payload 是主体部分,意为载体,承载着有效的 JWT 数据包,它包含三个部分
• 标准声明
• 公共声明
• 私有声明


• signature 是签证信息,该签证信息是通过header和payload,加上secret,通过算法加密生成。
• 公式 signature = 加密算法(header + “.” + payload, 密钥);
上面的 header 中,我们已经定义了加密算法使用 RS256,也已经实现了生成header和payload

快速实现jwt


创建springboot项目
创建test测试类

package com.liuyang;

import com.auth0.jwt.impl.JWTParser;
import io.jsonwebtoken.*;
import net.minidev.json.JSONUtil;

import java.util.Date;
import java.util.UUID;

public class Test {


    private long time =1000*60*60*24;

    private String signature="admin";
    @org.junit.jupiter.api.Test
    public void jwt(){

        JwtBuilder jwtBuilder = Jwts.builder();
        String jwtToken =jwtBuilder
                .setHeaderParam("typ","JWT")
                .setHeaderParam("alg","HS256")
                //payload
                .claim("username","tom")
                .claim("role","admin")
                .setSubject("admin-test")
                .setExpiration(new Date(System.currentTimeMillis()+time))
                .setId(UUID.randomUUID()+toString())
                //signature
                .signWith(SignatureAlgorithm.HS256,signature)
                .compact();
        System.out.println(jwtToken);

    }

    //解密
    @org.junit.jupiter.api.Test
    public void parse(){
        String token="eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VybmFtZSI6InRvbSIsInJvbGUiOiJhZG1pbiIsInN1YiI6ImFkbWluLXRlc3QiLCJleHAiOjE2NDE5NzIwMDEsImp0aSI6IjJjODc5ZmIxLTE1YzMtNDc0ZS04OTc4LTZiY2U3M2ZlY2IxNWNvbS5saXV5YW5nLlRlc3RANDc4ZGI5NTYifQ.-qVqqoKBup98nPgVmSvRwl1rt9TtW9mSu9EMvxdZbCk";
        JwtParser jwtParser =Jwts.parser();
        Jws claimsJws = jwtParser.setSigningKey(signature).parseClaimsJws(token);
        Claims claims = claimsJws.getBody();
        System.out.println(claims.get("username"));
        System.out.println(claims.get("role"));
        System.out.println(claims.getId());
        System.out.println(claims.getSubject());
        System.out.println(claims.getExpiration());

    }
}

加密

解密

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/704821.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号