使用es256算法生成jwt

1、使用hutool来做

1、先去jwt解密/加密 - bejson在线工具弄个公私钥

2、导入hutool maven

 <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.7.22</version>
        </dependency>
        <dependency>
            <groupId>org.bouncycastle</groupId>
            <artifactId>bcprov-jdk15to18</artifactId>
            <version>1.68</version>
        </dependency>

3、代码

public class JwtUtil {
    

    public static void main(String[] args) {
        System.out.println("jwt:" + genEs256Jwt("123"));
    }


    static String es256PrimaryKey = "xxx";

    static String es256PublicKey = "xxx";

   
    // 生成jwt
    @SneakyThrows
    public static String genEs256Jwt(String username){
        byte[] privateKeyBytes = Base64.decode(es256PrimaryKey);
        KeyFactory keyFactory = KeyFactory.getInstance("EC");
        PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(privateKeyBytes);
        PrivateKey privateKey = keyFactory.generatePrivate(keySpec);

        JWTSigner signer = JWTSignerUtil.es256(privateKey);
        String token = JWT.create()
                .setPayload("username", username)
                .setPayload("iss", "xxx")
                // 签发时间
                .setPayload("timeStamp",new Date().getTime())
                .setKey(secret)
                .setSigner(signer)
                .sign();
        
    }

  

4、解密

@SneakyThrows
    public static String parseEs256Jwt(String token){
        Security.addProvider(new BouncyCastleProvider());
        KeyFactory keyFactory = KeyFactory.getInstance("ECDH", "BC");

        byte[] publicKeyBytes = Base64.decode(es256PublicKey);
        X509EncodedKeySpec pubX509 = new X509EncodedKeySpec(publicKeyBytes);
        PublicKey publicKey = keyFactory.generatePublic(pubX509);


        JWTSigner signer = JWTSignerUtil.es256(publicKey);
        JWT jwt = JWT.of(token).setSigner(signer);
        return jwt.getPayload("username").toString();
    }

5、ps:hutool的在jwt解密/加密 - bejson在线工具上校验不过去,只能自己和自己校验玩

2、使用io.jsonwebtoken(推荐)

1、导入maven

<dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt-impl</artifactId>
            <version>0.11.1</version>
        </dependency>
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt-api</artifactId>
            <version>0.11.1</version>
        </dependency>
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt-jackson</artifactId>
            <version>0.11.1</version>
        </dependency>

2、代码

@SneakyThrows
    public static String genEs256Jwt(String username){
      
        Security.addProvider(new BouncyCastleProvider());
        byte[] privateKeyBytes = Base64.decode(es256PrimaryKey);
//        KeyFactory keyFactory = KeyFactory.getInstance("EC");
        KeyFactory keyFactory = KeyFactory.getInstance("ECDH", "BC");
        PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(privateKeyBytes);
        PrivateKey privateKey = keyFactory.generatePrivate(keySpec);

        Claims claims = Jwts.claims();
        claims.put("username", username);
        String token = Jwts.builder()
                .setClaims(claims)
                .setIssuer("xxx")
                .signWith(privateKey,SignatureAlgorithm.ES256)
//                .signWith(privateKey, SignatureAlgorithm.ES256)
                .compact();
        return token;
    }

3、解密

    @SneakyThrows
    public static String parseEs256Jwt(String token){
        Security.addProvider(new BouncyCastleProvider());
        KeyFactory keyFactory = KeyFactory.getInstance("ECDH", "BC");
        byte[] publicKeyBytes = Base64.decode(es256PublicKey);
        X509EncodedKeySpec pubX509 = new X509EncodedKeySpec(publicKeyBytes);
        PublicKey publicKey = keyFactory.generatePublic(pubX509);
        Jws<Claims> jwt = null;
        String username = null;
        try {
            jwt = Jwts.parserBuilder()
                    .setSigningKey(publicKey)
                    .build()
                    .parseClaimsJws(token);
            username = jwt.getBody().get("username").toString();
        } catch (ExpiredJwtException e) {
            e.printStackTrace();
        } catch (UnsupportedJwtException e) {
            e.printStackTrace();
        } catch (MalformedJwtException e) {
            e.printStackTrace();
        } catch (SignatureException e) {
            e.printStackTrace();
        } catch (IllegalArgumentException e) {
            e.printStackTrace();
        }

        return username;
    }

参考:JWT Token 使用 RS256 和 ES256 签名_jwt解码es256解密-CSDN博客

相关推荐

  1. 使用es256算法生成jwt

    2023-12-09 20:26:02       45 阅读
  2. JWT使用HS512算法生成全局服务token原理

    2023-12-09 20:26:02       45 阅读
  3. jsonwebtoken使用HS256生成token失败

    2023-12-09 20:26:02       32 阅读
  4. Android Apk签名算法使用SHA256

    2023-12-09 20:26:02       17 阅读
  5. gin中使用JWT

    2023-12-09 20:26:02       36 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-09 20:26:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-09 20:26:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-09 20:26:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-09 20:26:02       18 阅读

热门阅读

  1. Win32 枚举指定进程所有子窗口

    2023-12-09 20:26:02       35 阅读
  2. STM32的几个深入功能

    2023-12-09 20:26:02       32 阅读
  3. C# Bin、XML、Json的序列化和反序列化

    2023-12-09 20:26:02       36 阅读
  4. k8s中部署基于nfs的StorageClass

    2023-12-09 20:26:02       41 阅读
  5. 【PyTorch】计算设备

    2023-12-09 20:26:02       42 阅读
  6. 做题笔记:SQL Sever 方式做牛客SQL的题目--SQL156

    2023-12-09 20:26:02       34 阅读
  7. Nacos和Eureka冲突问题原因分析

    2023-12-09 20:26:02       38 阅读
  8. LeetCodehot100

    2023-12-09 20:26:02       35 阅读
  9. #HarmonyOS:基础语法

    2023-12-09 20:26:02       43 阅读