谁能给我一个使用 BouncyCastle 将 .pem 公共 DSA 密钥导入到 c# 中的示例?

发布于 2024-12-13 02:20:15 字数 1327 浏览 2 评论 0原文

我正在尝试将 .pem 密钥导入到 c# 中,并且我找到了一个库,它可以做到这一点: BouncyCastle< /a>

我创建了一个代码,它加载公钥并应该将数据加载到 DSACryptoServiceProvider 中:

        DSA dsa;

        using (StreamReader rdr = new StreamReader(@"pubkey.pem"))
        {
            PemReader pr = new PemReader(rdr);
            DsaPublicKeyParameters o = pr.ReadObject() as DsaPublicKeyParameters;
            CspParameters prm = new CspParameters(13);
            prm.Flags = System.Security.Cryptography.CspProviderFlags.UseMachineKeyStore; 
            //o.Parameters.
            dsa = new DSACryptoServiceProvider(prm);
            DSAParameters dp = new DSAParameters();
            dp.G = o.Parameters.G.ToByteArray();
            dp.P = o.Parameters.P.ToByteArray();
            dp.Q = o.Parameters.Q.ToByteArray();                
            dp.Y = o.Y.ToByteArray();

            if (o.Parameters.ValidationParameters != null)
            {
                dp.Counter = o.Parameters.ValidationParameters.Counter;
                dp.Seed = o.Parameters.ValidationParameters.GetSeed();
            }

            //todo: missing: J, X?
            dsa.ImportParameters(dp);
        }

它在 dsa.ImportParameters(dp); 上崩溃;但有以下异常:加密异常:错误数据。

我应该改变什么才能让它发挥作用?

I am trying co import a .pem key into c#, and I've found a library, which does that: BouncyCastle

I've created a code, which loads public key and is supposed to load the data into DSACryptoServiceProvider:

        DSA dsa;

        using (StreamReader rdr = new StreamReader(@"pubkey.pem"))
        {
            PemReader pr = new PemReader(rdr);
            DsaPublicKeyParameters o = pr.ReadObject() as DsaPublicKeyParameters;
            CspParameters prm = new CspParameters(13);
            prm.Flags = System.Security.Cryptography.CspProviderFlags.UseMachineKeyStore; 
            //o.Parameters.
            dsa = new DSACryptoServiceProvider(prm);
            DSAParameters dp = new DSAParameters();
            dp.G = o.Parameters.G.ToByteArray();
            dp.P = o.Parameters.P.ToByteArray();
            dp.Q = o.Parameters.Q.ToByteArray();                
            dp.Y = o.Y.ToByteArray();

            if (o.Parameters.ValidationParameters != null)
            {
                dp.Counter = o.Parameters.ValidationParameters.Counter;
                dp.Seed = o.Parameters.ValidationParameters.GetSeed();
            }

            //todo: missing: J, X?
            dsa.ImportParameters(dp);
        }

it crashes on dsa.ImportParameters(dp); with following exception: Cryptographic exception:bad data.

What should I change for this to work?

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

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

发布评论

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

评论(1

时光礼记 2024-12-20 02:20:15

您需要使用 ToByteArrayUnsigned 方法而不是普通的 ToByteArray 方法,否则在某些情况下,字节数组表示以前导零字节结束,这会破坏所有内容:)

You need to use the ToByteArrayUnsigned method instead of plain ToByteArray one as otherwise there are cases where the byte array representation ends up with a leading zero byte which breaks everything :)

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文