[英]Can anyone give me an example of using BouncyCastle to import .pem public DSA key into c#?
I am trying co import a .pem key into c#, and I've found a library, which does that: BouncyCastle 我正在尝试将.pem密钥共同导入c#,并且我找到了一个库,该库可以做到这一点: BouncyCastle
I've created a code, which loads public key and is supposed to load the data into DSACryptoServiceProvider: 我创建了一个代码,该代码加载公钥,并且应该将数据加载到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);
}
it crashes on dsa.ImportParameters(dp); 它在dsa.ImportParameters(dp)上崩溃; with following exception: Cryptographic exception:bad data.
有以下例外:密码例外:不良数据。
What should I change for this to work? 我该如何更改才能正常工作?
您需要使用ToByteArrayUnsigned
方法,而不是普通的ToByteArray
一个否则存在以下情况的字节数组表达结束了一个领先的零字节打破一切:)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.