依赖:
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt</artifactId>
<version>0.9.1</version>
</dependency>
<dependency>
<groupId>com.auth0</groupId>
<artifactId>java-jwt</artifactId>
<version>3.4.0</version>
</dependency>
<dependency>
<groupId>javax.xml.bind</groupId>
<artifactId>jaxb-api</artifactId>
<version>2.3.1</version>
</dependency>
工具类代码:import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm; import org.springframework.core.io.ClassPathResource; import org.springframework.security.rsa.crypto.KeyStoreKeyFactory;import java.security.KeyPair; import java.util.Date; import java.util.HashMap; import java.util.Map;/*** JWT工具类*/ public class JwtUtils {private static final Long expire = 1800000L;public static String generateJwt(Map<String, Object> claims) {return Jwts.builder().addClaims(claims).signWith(SignatureAlgorithm.RS256, keyPair().getPrivate()).setExpiration(new Date(System.currentTimeMillis() + expire)).compact();}public static KeyPair keyPair() {KeyStoreKeyFactory keyStoreKeyFactory = new KeyStoreKeyFactory(new ClassPathResource("jwt.jks"), "20211202".toCharArray());return keyStoreKeyFactory.getKeyPair("jwt", "20211202".toCharArray());}public static void main(String[] args) {Map<String, Object> map = new HashMap<>();map.put("id", 1);String jwt_token = JwtUtils.generateJwt(map);System.out.println("token:"+jwt_token);} }
生成jwt.jks文件放到自己的项目里