![](/img/trans.png)
[英]Convert an RSA PKCS1 private key string to a Java PrivateKey object
[英]Convert hex encoded ESCDA private key to Java PrivateKey interface
我正在嘗試實現自己的HyperLedger-Fabric SDK的Java用戶界面。 如果您不熟悉HyperLedger-Fabric,則請忽略此行,這是沒有必要的。
為此,我正在嘗試將此json(從fabric)轉換為私鑰:
"enrollment":
{
"signingIdentity":"e90c96e1919de2971913c5a7a3e09ccc13f1a765f64c7949e9ee50a26721ed9b",
"identity":
{
"certificate":
"-----BEGIN CERTIFICATE-----\nMIIB8TCCAZegAwIBAgIUbIsZfWI2ETkBp745jW87ATqS0zAwCgYIKoZIzj0EAwIw\nczELMAkGA1UEBhMCVVMxEzARBgNVBAgTCkNhbGlmb3JuaWExFjAUBgNVBAcTDVNh\nbiBGcmFuY2lzY28xGTAXBgNVBAoTEG9yZzEuZXhhbXBsZS5jb20xHDAaBgNVBAMT\nE2NhLm9yZzEuZXhhbXBsZS5jb20wHhcNMTcxMjEzMTU1MzAwWhcNMTgxMjEzMTU1\nMzAwWjAQMQ4wDAYDVQQDEwV1c2VyMTBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IA\nBJyAKHhZR82HgkdjXJqYUogNSAn4MtrZq62534/9bOQLBBoe3ySFXvecE5/jBKwV\nQwLpsfpow9YbHxrA4WkkJ9CjbDBqMA4GA1UdDwEB/wQEAwIHgDAMBgNVHRMBAf8E\nAjAAMB0GA1UdDgQWBBT6IGsIp5IEYqYxntl3N8SyOfYYoDArBgNVHSMEJDAigCBC\nOaoNzXba7ri6DNpwGFHRRQTTGq0bLd3brGpXNl5JfDAKBggqhkjOPQQDAgNIADBF\nAiEAh9yjeFMFDbw9Uijz3nJrC2sXc1mpISxalgK6UmkadoACIEXKlU+XqHj9bV/Y\nQpA7aDaWLsOFYCgTSrHNNFsFWBbQ\n-----END CERTIFICATE-----\n"
}
}
私鑰位於“ signingIdentity”字段中(它只是測試私鑰,請根據需要使用它:-))。
從我所聽到的信息來看,超級分類帳結構使用ESCDA,因此應該是橢圓曲線。
但是我不知道如何從這些數據中生成正確的Java PrivateKey實例...
以下應該為您做的工作:
try (PEMParser parser = new PEMParser(new StringReader(/*PUT signingIdentity here*/)) {
pemPair = (PrivateKeyInfo) parser.readObject();
JcaPEMKeyConverter pemConverter = new JcaPEMKeyConverter();
return pemConverter
.setProvider(BouncyCastleProvider.PROVIDER_NAME)
.getPrivateKey(pemPair);
}
當然,您需要BouncyCastle lib的支持:
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcpkix-jdk15on</artifactId>
<version>1.55</version>
</dependency>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.