没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
 
                
            原创|其它|编辑:郝浩|2012-09-14 16:32:39.000|阅读 505 次
概述:数字签名能有效地防止他人对文件的篡改,进而为文件的可信度提供保障。所以,很多人都想知道:如何用Aspose.Cells为电子表格文件添加数字签名。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
数字签名能有效地防止他人对文件的篡改,进而为文件的可信度提供保障。所以,很多人都想知道:如何用Aspose.Cells为电子表格文件添加数字签名?
Aspose.Cells提供Aspose.Cells.DigitalSignatures命名空间来执行这个任务。我们只需使用the Digital Signature dialog box (数字签名对话框)就能为文件添加数字签名。数字签名对话框中列出了有效的证书,我们可以使用数字签名对话框来查看证书,并选择要使用的证书。
下面,我们就给出具体的事例代码供大家参考:
[C#]
 using System;
using System.IO;
using Aspose.Cells;
using System.Collections;
using System.Text;
using System.Threading;
using Aspose.Cells.Rendering;
using System.Security.Cryptography;
using System.Drawing;
using System.Diagnostics;
using Aspose.Cells.DigitalSignatures;
using System.Security.Cryptography.X509Certificates;
namespace Aspose.Cells.test
{
    /// <summary>
    /// Summary description for MyTest.
    /// </summary>
    class MyTest
    {
        public MyTest()
        {
        }
        [STAThread]
        static void Main(string[] args)
        {
            MyTest test = new MyTest();
            test.testSign();
            test.testvalidateSign();
            Console.ReadLine();
        }
        internal void testvalidateSign()
        {
            //instantiate and open the file
            Workbook wb = new Workbook(@"e:\test\digital signatures\newfile.xlsx");
            //wb.IsDigitallySigned is true when the workbook is signed already.
            System.Console.WriteLine(wb.IsDigitallySigned); //True -OK
            //get digitalSignature collection from workbook
            DigitalSignatureCollection dsc = wb.GetDigitalSignature();
            foreach (DigitalSignature ds in dsc)
            {
                System.Console.WriteLine(ds.Comments); //test for sign -OK
                System.Console.WriteLine(ds.SignTime); //11/25/2010 1:22:01 PM -OK
                System.Console.WriteLine(ds.IsValid); //True -OK
            }
        }
        internal void testSign()
        {
            //dsc is signature collection contains one or more signature needed to sign
            DigitalSignatureCollection dsc = new DigitalSignatureCollection();
            //cert must contain private key, it can be contructed from cert file or windows certificate collection.
            //123456 is password of cert
            X509Certificate2 cert = new X509Certificate2("e:\\test\\digital signatures\\mykey2.pfx", "123456");
            DigitalSignature ds = new DigitalSignature(cert, "test for sign", DateTime.Now);
            dsc.Add(ds);
            Workbook wb = new Workbook();
            //wb.SetDigitalSignature signs all signatures in dsc
            wb.SetDigitalSignature(dsc);
            wb.Save(@"e:\test\digital signatures\newfile.xlsx");
        }
    }
}
 
[VB]
 Imports System
Imports System.IO
Imports Aspose.Cells
Imports System.Collections
Imports System.Text
Imports System.Threading
Imports Aspose.Cells.Rendering
Imports System.Security.Cryptography
Imports System.Drawing
Imports System.Diagnostics
Imports Aspose.Cells.DigitalSignatures
Imports System.Security.Cryptography.X509Certificates
Namespace Aspose.Cells.test
 ''' <summary>
 ''' Summary description for MyTest.
 ''' </summary>
 Friend Class MyTest
  Public Sub New()
  End Sub
  <STAThread> _
  Shared Sub Main(ByVal args() As String)
   Dim test As New MyTest()
   test.testSign()
   test.testvalidateSign()
   Console.ReadLine()
  End Sub
  Friend Sub testvalidateSign()
   'instantiate and open the file
   Dim wb As New Workbook("e:\test\digital signatures\newfile.xlsx")
   'wb.IsDigitallySigned is true when the workbook is signed already.
   System.Console.WriteLine(wb.IsDigitallySigned) 'True -OK
   'get digitalSignature collection from workbook
   Dim dsc As DigitalSignatureCollection = wb.GetDigitalSignature()
   For Each ds As DigitalSignature In dsc
   System.Console.WriteLine(ds.Comments) 'test for sign -OK
   System.Console.WriteLine(ds.SignTime) '11/25/2010 1:22:01 PM -OK
   System.Console.WriteLine(ds.IsValid) 'True -OK
   Next ds
  End Sub
Friend Sub testSign()
  'dsc is signature collection contains one or more signature needed to sign
  Dim dsc As New DigitalSignatureCollection()
  'cert must contain private key, it can be contructed from cert file or windows certificate collection.
   '123456 is password of cert
  Dim cert As New X509Certificate2("e:\test\digital signatures\mykey2.pfx", "123456")
   Dim ds As New DigitalSignature(cert, "test for sign", DateTime.Now)
   dsc.Add(ds)
   Dim wb As New Workbook()
   'wb.SetDigitalSignature signs all signatures in dsc
   wb.SetDigitalSignature(dsc)
   wb.Save("e:\test\digital signatures\newfile.xlsx")
  End Sub
 End Class
End Namespace
在运行上述的代码后,我们为电子表格添加的数字签名效果图如下:

我们可以用MS Excel 查看数字标签的具体信息:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@ke049m.cn
文章转载自:慧都控件网



 
					接DevExpress原厂商通知,将于近日上调旗下产品授权价格,现在下单客户可享受优惠报价!
 
					面对“数字中国”建设和中国制造2025战略实施的机遇期,中车信息公司紧跟时代的步伐,以“集约化、专业化、标准化、精益化、一体化、平台化”为工作目标,大力推进信息服务、工业软件等核心产品及业务的发展。在慧都3D解决方案的实施下,清软英泰建成了多模型来源的综合轻量化显示平台、实现文件不失真的百倍压缩比、针对模型中的大模型文件,在展示平台上进行流畅展示,提升工作效率,优化了使用体验。
 
					本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
 
					本站的模型资源均免费下载,登录后即可下载。模型仅供学习交流,勿做商业用途。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@ke049m.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
 
                 
            
 半岛外围网上直营
半岛外围网上直营  
					 
					 
					 
					 
					