4 votes

Quelqu'un peut-il me donner un exemple d'utilisation de BouncyCastle pour importer une clé publique DSA .pem en c# ?

J'essaie d'importer une clé .pem en C#, et j'ai trouvé une bibliothèque qui le fait : Château gonflable

J'ai créé un code, qui charge la clé publique et est censé charger les données dans 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);
        }

il se bloque sur dsa.ImportParameters(dp) ; avec l'exception suivante : Exception cryptographique : mauvaises données.

Que dois-je changer pour que cela fonctionne ?

2voto

tyranid Points 7996

Vous devez utiliser le ToByteArrayUnsigned au lieu de la simple méthode ToByteArray car sinon il y a des cas où la représentation du tableau d'octets se retrouve avec un octet zéro en tête, ce qui casse tout :)

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X