Bir zırhlı ECC gpg anahtarını karşılık gelen java sınıfına dönüştürmeye çalışıyorum ECPrivateKey/ECPublicKey. gpg --expert --full-generate-key
Ayrıştırılmış ECC genel/özel anahtarlar (gpg ile oluşturulmuştur) java
Sonra (9) ECC ve ECC (ya da (10) ECC() yalnızca oturum) seçerek
Sonra seçilmesi (3) NIST P-:
kullanıyorum anahtar çifti oluşturmak için sonuçlanan 256:
-----BEGIN PGP PUBLIC KEY BLOCK-----
mFIEWUdzwhMIKoZIzj0DAQcCAwQkAvZC1PIJ8ke1myyKhNny9vN78TIYo2MuAOY+
F38L9S3+Za9cKV/iIHOqfapbMoqdSmSnqDkevwQSr5MF2UOXtCJzaWduZWNjIChF
Q0Mgc2lnbiBvbmx5KSA8c3NAc3MuY28+iJAEExMIADgWIQRiC+kefVkjnjKovKy5
XANFl5+n1gUCWUdzwgIbAwULCQgHAgYVCAkKCwIEFgIDAQIeAQIXgAAKCRC5XANF
l5+n1mzGAQDsgutymxDTTXPKFfpFFVp4fxacx1MSqxP71gNJYjguXwD8CEXD20Vm
aU1WMi2jU7JC6oJn94Y4vWHwTLOU1zmQ19o=
=swfS
-----END PGP PUBLIC KEY BLOCK-----
-----BEGIN PGP PRIVATE KEY BLOCK-----
lHcEWUdzwhMIKoZIzj0DAQcCAwQkAvZC1PIJ8ke1myyKhNny9vN78TIYo2MuAOY+
F38L9S3+Za9cKV/iIHOqfapbMoqdSmSnqDkevwQSr5MF2UOXAAD9FhS2HZoWOyIi
l9nj+WPa9S1o50jM5bNIRALzcyS8SgoP97Qic2lnbmVjYyAoRUNDIHNpZ24gb25s
eSkgPHNzQHNzLmNvPoiQBBMTCAA4FiEEYgvpHn1ZI54yqLysuVwDRZefp9YFAllH
c8ICGwMFCwkIBwIGFQgJCgsCBBYCAwECHgECF4AACgkQuVwDRZefp9ZsxgEA7ILr
cpsQ001zyhX6RRVaeH8WnMdTEqsT+9YDSWI4Ll8A/AhFw9tFZmlNVjIto1OyQuqC
Z/eGOL1h8EyzlNc5kNfa
=qHBB
-----END PGP PRIVATE KEY BLOCK-----
nasıl geçerli java.security.interfaces.ECPrivateKey ve java.security.interfaces.ECP bu zırhlı metin biçiminden alırım ublicKey java sınıfları?
private static ECPrivateKey privateKeyParse(byte[] privateKey) throws Exception
{
InputStream pgpIn = PGPUtil.getDecoderStream(new ByteArrayInputStream(privateKey));
PGPObjectFactory pgpFact = new PGPObjectFactory(pgpIn, new JcaKeyFingerprintCalculator());
PGPSecretKeyRing pgpSecRing = (PGPSecretKeyRing)pgpFact.nextObject();
PGPSecretKey pgpSec = pgpSecRing.getSecretKey();
PGPPrivateKey pgpPriv = pgpSec.extractPrivateKey(null);
return (ECPrivateKey)new JcaPGPKeyConverter().getPrivateKey(pgpPriv);
}
bir cevap vermek için: sadece 'özel anahtar blok' geçerseniz
String createSignatureFromJson(String jsonPayload, byte[] privateKey) {
Payload payload = new Payload(jsonPayload)
def key = privateKeyParse(privateKey)
JWSSigner signer = new ECDSASigner((ECPrivateKey)key)
JWSHeader header = new JWSHeader.Builder(JWSAlgorithm.ES256).build()
JWSObject jwsObject = new JWSObject(header, payload)
jwsObject.sign(signer)
jwsObject.signature
}
Eğer byte [] privateKey parametreye özel anahtar bloktan almak konusunda daha fazla spesifik olabilir: Bir byte [] içine tüm dosyayı okumak? –
Ben java.io.IOException alıyorum: bilinmeyen PGP genel anahtar algoritması üzerinde karşılaştı: PGPSecretKeyRing pgpSecRing = (PGPSecretKeyRing) pgpFact.nextObject() aşağıdaki şekilde yönteme özel anahtar bloğu temin: privateKeyBlock. split ('\ n'). join(). bytes –
Kullandığınız BC sürümü nedir? PGP EC anahtarlarının sadece 1.50'den desteklendiğini düşünüyorum. –