簡體   English   中英

將十六進制編碼的ESCDA私鑰轉換為Java PrivateKey接口

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM