要解析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)。