JWT签名算法比较多,主要分为非对称算法和对称算法,支持的算法定义在SignAlgorithm中。
RS512(SHA512withRSA)
JWTSignerUtil中预定义了一些算法的签名器的创建方法,如创建HS256的签名器:
final JWTSigner signer = JWTSignerUtil.hs256("123456".getBytes());
JWT jwt = JWT.create().setSigner(signer);
通过JWTSignerUtil.createSigner即可通过动态传入algorithmId创建对应的签名器,如我们如果需要实现ps256算法,则首先引入bcprov-jdk15to18包:
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15to18</artifactId>
<version>1.69</version>
</dependency>
再创建对应签名器即可:
String id = "ps256";
final JWTSigner signer = JWTSignerUtil.createSigner(id, KeyUtil.generateKeyPair(AlgorithmUtil.getAlgorithm(id)));
JWT jwt = JWT.create().setSigner(signer);
JWTSigner接口是一个通用的签名器接口,如果想实现自定义算法,实现此接口即可。