谁能给我一个使用BouncyCastle将.pem公共DSA密钥导入c#的例子?
发布时间:2020-12-15 17:21:21 所属栏目:百科 来源:网络整理
导读:我正在尝试将.pem密钥导入c#,我找到了一个库,它可以做到: BouncyCastle 我创建了一个代码,它加载公钥并且应该将数据加载到DSACryptoServiceProvider中: DSA dsa; using (StreamReader rdr = new StreamReader(@"pubkey.pem")) { PemReader pr = new PemRea
我正在尝试将.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方法,否则有些情况下字节数组表示最后会有一个前导零字节,它会破坏所有内容:)
(编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |