c# - 为什么我只有 5% 的时间收到错误数据异常?

标签 c# .net encryption cryptography bouncycastle

我有以下代码,大约有 5% 的时间抛出 CryptographicException,我无法弄清楚为什么 a) 它不会始终失败以及 b) 为什么它根本失败:

// Initialize the new secure keys
var keyGenerator = KeyGenerator.Create();
var keyPair = keyGenerator.GenerateKeyPair();
this._privateKey = keyPair.ToEncryptedPrivateKeyString(privateKeySecret);
this._publicKey = keyPair.ToPublicKeyString();

// Initialize the certificate generation
var certificateGenerator = new X509V3CertificateGenerator();
var serialNo = BigInteger.ProbablePrime(128, new Random());
certificateGenerator.SetSerialNumber(serialNo);
certificateGenerator.SetSubjectDN(GetLicenseeDN());
certificateGenerator.SetIssuerDN(GetLicencerDN());
certificateGenerator.SetNotAfter(DateTime.Now.AddYears(100));
certificateGenerator.SetNotBefore(DateTime.Now.Subtract(new TimeSpan(7, 0, 0, 0)));
certificateGenerator.SetSignatureAlgorithm("SHA512withRSA");
certificateGenerator.SetPublicKey(keyPair.PublicKey);
var result = certificateGenerator.Generate(keyPair.PrivateKey);
this._clientCertificate = new X509Certificate2(DotNetUtilities.ToX509Certificate(result));
this._clientCertificate.PrivateKey = DotNetUtilities.ToRSA((RsaPrivateCrtKeyParameters)keyPair.PrivateKey);

堆栈看起来像:

System.Security.Cryptography.CryptographicException: Bad Data.
Result StackTrace:  
at System.Security.Cryptography.CryptographicException.ThrowCryptographicException(Int32 hr)
   at System.Security.Cryptography.Utils._ImportKey(SafeProvHandle hCSP, Int32 keyNumber, CspProviderFlags flags, Object cspObject, SafeKeyHandle& hKey)
   at System.Security.Cryptography.RSACryptoServiceProvider.ImportParameters(RSAParameters parameters)
   at Org.BouncyCastle.Security.DotNetUtilities.ToRSA(RsaPrivateCrtKeyParameters privKey) in C:\BouncyCastle\crypto\src\security\DotNetUtilities.cs:line 173
   at EBSConnect.EBSClientBase.InitializeSecurity(String privateKeySecret) in c:\Projects\EBSConnect\Source\EBSConnect\EBSClientBase.cs:line 78

其余时间 (95%),此代码按预期工作,我能够使用此动态生成的证书与联合服务通信。有什么想法吗?

最佳答案

假设您使用的是 BouncyCaSTLe C# 1.7,从 BigInteger 到 byte[] 的转换存在一些问题(与前导零有关)。这些已在源代码中修复,但尚未发布。我建议制作最新的本地副本 DotNetUtilities类并在您的项目中使用它,直到有新版本可用。

关于c# - 为什么我只有 5% 的时间收到错误数据异常?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17492257/

相关文章:

c# - 空检查的 "is"类型模式表达式

c# - 如何使用 uint 作为键在字典中存储函数 (C#)

c# - 无法使用 JavaScriptDateTimeConverter 解析数据

.net - 从 .net 4.6.2 库中引用 .NET Standard 1.6 库

java - 服务器无法解密Android 4.2发送的消息

java - 如何加密桌面应用程序和基于 REST 的 Web 服务之间的通信?

Android——加密与解密

c# - 以编程方式更改屏幕色彩平衡

c# - 将 IEnumerable<T> 导出到 Excel

.net - 发出方法来覆盖非虚拟对象