2017-08-30 8 views
1

JavaのBouncy Castleの公開鍵または秘密鍵から実際の鍵を取得すると(実際のクラスはBCECPublicKeyとBCECPrivateKeyのようです)キーオブジェクトをコード内で使用するために再構築することは可能ですか?Bouncy Castleでプライベートキーと公開キーを再構築しますか?

私はここで、オブジェクト全体をバイナリ(そしてディスク)にシリアル化して、バイナリと適切なクラスのオブジェクトに戻す方法を見つけましたが、シリアル化に実装の詳細が含まれていると思います。バウンシーキャッスル以外のものでそれらのキーを使用しようとすると、失敗します。私は今それをやろうとはしていないが、将来的に私のプログラムを証明したい。

KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("EC", "BC"); 
    keyPairGenerator.initialize(new ECGenParameterSpec("secp521r1"), new SecureRandom()); 
    java.security.KeyPair keyPair = keyPairGenerator.generateKeyPair(); 

    privateKey = keyPair.getPrivate(); 
    publicKey = keyPair.getPublic(); 

答えて

2

KeyFactoryがエンコードされたキーとそれらを表すJavaクラス間の変換に使用されます。

これは、私は、キーを作成しています方法です。ただし、KeyFactoryインスタンスは、バイト配列とKeyクラスの間で直接変換されません。その代わりに、エンコーディングが使用する形式を既に知っていて、コンストラクタでバイト配列を使用してKeySpecオブジェクトを作成する必要があります。形式は、キーのメソッドを呼び出すことによって決定できます。ここでは、これらの点の例を示します。

import org.bouncycastle.jce.provider.BouncyCastleProvider; 

import java.security.*; 
import java.security.spec.ECGenParameterSpec; 
import java.security.spec.PKCS8EncodedKeySpec; 
import java.security.spec.X509EncodedKeySpec; 

public class Main { 

    public static void main(String[] args) throws Exception{ 
     Security.addProvider(new BouncyCastleProvider()); 
     KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("EC", "BC"); 
     keyPairGenerator.initialize(new ECGenParameterSpec("secp521r1"), new SecureRandom()); 
     java.security.KeyPair keyPair = keyPairGenerator.generateKeyPair(); 

     PrivateKey privateKey = keyPair.getPrivate(); 
     System.out.println(privateKey.getFormat()); 
     PublicKey publicKey = keyPair.getPublic(); 
     System.out.println(publicKey.getFormat()); 

     // A KeyFactory is used to convert encoded keys to their actual Java classes 
     KeyFactory ecKeyFac = KeyFactory.getInstance("EC", "BC"); 

     // Now do a round-trip for a private key, 
     byte [] encodedPriv = privateKey.getEncoded(); 
     // now take the encoded value and recreate the private key 
     PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(encodedPriv); 
     PrivateKey privateKey2 = ecKeyFac.generatePrivate(pkcs8EncodedKeySpec); 

     // And a round trip for the public key as well. 
     byte [] encodedPub = publicKey.getEncoded(); 
     X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(encodedPub); 
     PublicKey publicKey2 = ecKeyFac.generatePublic(x509EncodedKeySpec); 
     System.out.println(publicKey2); 

    } 
} 
+0

Ah! KeyFactory。私はそのクラスを知らなかった。ありがとうございました。私は明日の朝、もっと詳しく調べてみましょう。 – Pablo

+0

それはうまくいった。ありがとうございました。 – Pablo

関連する問題