簡體   English   中英

誰能給我一個使用BouncyCastle將.pem公共DSA密鑰導入c#的示例嗎?

[英]Can anyone give me an example of using BouncyCastle to import .pem public DSA key into 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一個否則存在以下情況的字節數組表達結束了一個領先的零字節打破一切:)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM