微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

我正在尝试将.pem密钥导入c#,我找到了一个库,它可以做到: BouncyCastle

我创建了一个代码,它加载公钥并且应该将数据加载到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)上崩溃;以下异常:加密异常:错误数据.

我应该改变什么才能工作?

解决方法

你需要使用ToByteArrayUnsigned方法而不是普通的ToByteArray方法,否则有些情况下字节数组表示最后会有一个前导零字节,它会破坏所有内容:)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐