Как преобразовать экземпляр ECDiffieHellmanPublicKey в файл DER в.NET Framework?

У меня есть следующий код:

ECDiffieHellman ecdh = ECDiffieHellman.Create(ECCurve.NamedCurves.nistP256);
ECDiffieHellmanPublicKey ecdhPublic = ecdh.PublicKey;

Как я могу экспортировать экземпляр ECDiffieHellmanPublicKey (ecdhPublic) в кодированный файл DER?

1 ответ

Решение

Используя BouncyCastle ( http://www.bouncycastle.org/), вы можете экспортировать свой открытый ключ ECDH в объект ANS.1 в кодировке DER.

X9ECParameters ecP = NistNamedCurves.GetByName("P-256");
ECDomainParameters ecSpec = new ECDomainParameters(ecP.Curve, ecP.G, ecP.N, ecP.H, ecP.GetSeed());
ECKeyPairGenerator g = new ECKeyPairGenerator();
g.Init(new ECKeyGenerationParameters(ecSpec, new SecureRandom()));

AsymmetricCipherKeyPair server = g.GenerateKeyPair();
ECPublicKeyParameters serverPub = (ECPublicKeyParameters)server.Public;
var result = SubjectPublicKeyInfoFactory.CreateSubjectPublicKeyInfo(serverPub).GetDerEncoded();
Другие вопросы по тегам