温馨提示×

解析JWT时io.jsonwebtoken怎么用

小樊
196
2024-06-15 17:13:48
栏目: 编程语言

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

0