要解析JWT时,可以使用io.jsonwebtoken库中的JwtParser类。下面是一个简单的示例代码来解析JWT:
import io.jsonwebtoken.Claims; import io.jsonwebtoken.Jwts; import io.jsonwebtoken.SignatureAlgorithm; import io.jsonwebtoken.security.Keys; import java.security.Key; public class JwtParserExample { public static void main(String[] args) { String secret = "mySecretKey"; Key key = Keys.hmacShaKeyFor(secret.getBytes()); String jwt = "eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsImlhdCI6MTYyNTE1Njg4MCwiZXhwIjoxNjI1MTU2ODgwfQ.Uk4z_s3BzuTtLvz5W0ePbP3ZVvQ3IjQ3g5N9OP5J5F0"; Claims claims = Jwts.parserBuilder() .setSigningKey(key) .build() .parseClaimsJws(jwt) .getBody(); String subject = claims.getSubject(); System.out.println("Subject: " + subject); Long issuedAt = claims.getIssuedAt().getTime(); System.out.println("Issued At: " + issuedAt); Long expiration = claims.getExpiration().getTime(); System.out.println("Expiration: " + expiration); } }
在上面的示例中,首先创建了一个密钥,然后使用该密钥解析JWT。通过调用parseClaimsJws
方法,可以获取JWT中的声明(claims),然后可以通过claims对象获取JWT中的不同声明内容,例如主题(subject)、签发时间(issuedAt)和过期时间(expiration)。