Как настроить RSAKey.Builder для получения простого результата без нулевых значений
У меня такой код:
// get keyPair...
final JWK jwk = new RSAKey.Builder((RSAPublicKey) keyPair.getPublic())
.privateKey((RSAPrivateKey) keyPair.getPrivate())
.keyUse(KeyUse.SIGNATURE)
.algorithm(JWSAlgorithm.RS256)
.keyID("1")
.build();
return new JWKSet(jwk.toPublicJWK());
Результат будет примерно таким:
keys: [
{
keyStore: null,
private: false,
modulus: { },
privateExponent: null,
publicExponent: { },
secondPrimeFactor: null,
firstPrimeFactor: null,
secondFactorCRTExponent: null,
firstCRTCoefficient: null,
firstFactorCRTExponent: null,
requiredParams: {
e: "AQAB",
kty: "RSA",
n: "123456789-987654321...etc."
},
otherPrimes: [ ],
algorithm: {
name: "RS256",
requirement: null
},
keyType: {
value: "RSA",
requirement: "REQUIRED"
},
x509CertThumbprint: null,
x509CertSHA256Thumbprint: null,
parsedX509CertChain: null,
keyID: "1",
keyUse: {
value: "sig"
},
keyOperations: null,
x509CertURL: null,
x509CertChain: null
}
],
additionalMembers: { }
}
Я ожидал чего-нибудь попроще, например:
{
"keys": [
{
"kty": "RSA",
"e": "AQAB",
"use": "sig",
"kid": "65b413b1-94c8-48ce-a79a-ba4978460205",
"alg": "RS256",
"n": "123456789-987654321...etc."
}
]
}
Что мне делать, чтобы создать этот формат вместо прежнего?
1 ответ
Моя проблема, моя конечная точка была неправильной.
Вместо:
@GetMapping
public ResponseEntity<JWKSet> getJwks() {
return ResponseEntity
.status(HttpStatus.OK)
.body(jwksService.getJwkSet());
}
предполагается:
@GetMapping
public Map<String, Object> getJwks() {
return jwksService.getJwkSet().toJSONObject(true);
}