gpt4 book ai didi

c# - 谁能给我一个使用 BouncyCaSTLe 将 .pem 公共(public) DSA key 导入 c# 的示例?

转载 作者:行者123 更新时间:2023-11-30 12:34:01 25 4
gpt4 key购买 nike

我正在尝试将 .pem key 共同导入到 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) 上崩溃;有以下异常(exception):加密异常:错误数据。

我应该更改什么才能使其正常工作?

最佳答案

您需要使用 ToByteArrayUnsigned 方法而不是普通的 ToByteArray 方法,否则会出现字节数组表示以前导零字节结尾的情况,这会破坏所有内容: )

关于c# - 谁能给我一个使用 BouncyCaSTLe 将 .pem 公共(public) DSA key 导入 c# 的示例?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7946984/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com