首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在c#中使用System.IO.Packaging对.xlsx文件进行数字签名

在c#中使用System.IO.Packaging对.xlsx文件进行数字签名
EN

Stack Overflow用户
提问于 2020-01-14 21:59:18
回答 1查看 203关注 0票数 0

问候,

我正在尝试使用System.IO.Packaging对excel文件进行数字签名,但我无法正常工作。

我使用的简化代码如下:

代码语言:javascript
复制
var packageFile = @"C:\temp\test.xlsx";
var package = Package.Open(packageFile, FileMode.Open);
var packageDigitalSignatureManager = new PackageDigitalSignatureManager(package);
var uriCollection = package.GetParts().ToList().Select(part => part.Uri);
X509Certificate2 cert = new X509Certificate2(@"D:\certs\adrianganea.pfx", "password", X509KeyStorageFlags.Exportable);
var signature = packageDigitalSignatureManager.Sign(uriCollection, cert);

文档似乎已签名,但签名无效:Invalid Signatures

有什么想法吗?

非常感谢,艾利安

EN

回答 1

Stack Overflow用户

发布于 2020-01-15 16:41:41

不要紧,似乎需要嵌入签名证书:packageDigitalSignatureManager .CertificateOption =CertificateEmbeddingOption.InSignaturePart;

link包含一个很好的示例。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59735290

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档