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

本文关键字:pem 导入 BouncyCastle 使用 公共 DSA 密钥 一个 | 更新日期: 2023-09-27 18:12:42

我正在尝试将。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);加密异常:bad data.

我应该怎么做才能使它工作?

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

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