如何读取der文件并转换为AsymmetryCipherKeyPair?

发布于 2024-12-26 12:18:41 字数 327 浏览 0 评论 0原文

我有一个 der 文件“text.der”,其中包含 DER 编码的密钥。我想读取它并转换为 Bouncycastle C# 库中的 AmetryCipherKeyPair 实例 (这里是 Java 版本的 javadoc)

例如,对于pem文件,我们在bouncycastle中有PemReader/Writer,我们可以做到这一点。 如何从文件中的编码密钥转换为非对称密码密钥对

I have a der file 'text.der' that contains a DER-encoded key. I want read it and convert to an instance of AsymmetricCipherKeyPair from the Bouncycastle C# library (here are the javadocs for the Java version).

For example for a pem file, we have PemReader/Writer in bouncycastle and we can do it.
How can I go from the encoded key in a file to an AsymmetricCipherKeyPair

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

拒绝两难 2025-01-02 12:18:41

假设它是通常的二进制格式 DER 公钥文件,并且具有用于 SubjectPublicKeyInfo 结构的二进制 DER 编码(我认为 OpenSSL 将其用于其 DER 输出格式),您可以

byte[] derKeyBytes = File.ReadAllBytes("text.der"); // read in the binary file

// Decode the public key component
AsymmetricKeyParameter publicKey =
    PublicKeyFactory.CreateKey(derKeyBytes);

这样 做:密钥的公共部分),但如果您绝对希望将其放在非对称密码密钥对中,则可以执行以下操作:

// Put the public key into a keyPair, leave the Private key uninitialized.
AsymmetricCipherKeyPair keyPair =
    new AsymmetricCipherKeyPair(
        publicKey,
        new AsymmetricKeyParameter(true));

Assuming its the usual binary format DER public key file, with the binary DER coding for the SubjectPublicKeyInfo structure (I think OpenSSL uses this for its DER output format), you can do:

byte[] derKeyBytes = File.ReadAllBytes("text.der"); // read in the binary file

// Decode the public key component
AsymmetricKeyParameter publicKey =
    PublicKeyFactory.CreateKey(derKeyBytes);

You're better of just using the AsymmetricKeyParameter (which is the public part of the key), but if you absolutely want it in a AsymmetricCipherKeyPair, you can do this:

// Put the public key into a keyPair, leave the Private key uninitialized.
AsymmetricCipherKeyPair keyPair =
    new AsymmetricCipherKeyPair(
        publicKey,
        new AsymmetricKeyParameter(true));
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文