我正在尝试将.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)上崩溃;以下例外:加密异常:错误数据。
我应该为此做些什么改变?
答案 0 :(得分:2)
你需要使用ToByteArrayUnsigned
方法而不是普通ToByteArray
方法,否则有些情况下字节数组表示最终会有一个前导零字节,它会破坏所有内容:)