【发布时间】:2017-12-25 16:11:45
【问题描述】:
我想用 .Net Core (2.0) 创建 PKCS#7 分离签名。
我在这里阅读了与我的问题或多或少相关的所有答案,并找到了this 和this 的答案。其他人都束手无策。第一个示例完全符合我的需要,但它依赖于 .NetFramework。
第二个使用 Bouncy Castle 库并做一些不同但相似的事情。我发现Portable.BouncyCastle 项目在.Net Core 上运行。据我所知,这是我唯一的选择。
这是第一个示例的代码,经过一些修改:
string s = "data string";
byte[] data = Encoding.UTF8.GetBytes(s);
X509Certificate2 certificate = null;
X509Store my = new X509Store(StoreName.My,StoreLocation.CurrentUser);
my.Open(OpenFlags.ReadOnly);
certificate = my.Certificates.Find(X509FindType.FindByThumbprint, "my thumbprint", false)[0];
if (certificate == null) throw new Exception("No certificates found.");
ContentInfo content = new ContentInfo(new Oid("1.2.840.113549.1.7.1"),data);
SignedCms signedCms = new SignedCms(content, true);
CmsSigner signer = new CmsSigner(certificate);
signer.DigestAlgorithm = new Oid("SHA256");
// create the signature
signedCms.ComputeSignature(signer);
return signedCms.Encode();
在我的情况下它工作正常。 signedCms.Encode() 返回 1835 字节,此值通过验证。
但如果我使用 BounceCastle,我会得到另一个结果。这是代码:
X509Certificate2 certificate = null;
X509Store my = new X509Store(StoreName.My, StoreLocation.CurrentUser);
my.Open(OpenFlags.ReadOnly);
certificate = my.Certificates.Find(X509FindType.FindByThumbprint, "my thumbprint", false)[0];
var privKey = DotNetUtilities.GetRsaKeyPair(certificate.GetRSAPrivateKey()).Private;
var cert = DotNetUtilities.FromX509Certificate(certificate);
var content = new CmsProcessableByteArray(data);
var generator = new CmsSignedDataGenerator();
generator.AddSigner(privKey, cert, CmsSignedGenerator.EncryptionRsa, CmsSignedGenerator.DigestSha256);
var signedContent = generator.Generate(content, false);
return signedContent.GetEncoded();
signedContent.GetEncoded() 返回 502 字节,此结果无法验证。我知道我做错了什么,但我不知道是什么。
我应该如何使用 Bouncy Castle 修改示例,以获得与上面代码相同的结果?
【问题讨论】:
-
您在使用 CmsSignedDataGenerator 时没有指定 Oid,可能是这个原因吗?
-
值得一提的是:SignedCms 已添加到 .NET Core 2.1。
标签: c# .net-core bouncycastle pkcs#7