Spire.Cloud.PDF 加密、解密 PDF 文档

Spire.Cloud.PDF.SDK提供了接口PdfSecurityApi可用于加密、解密PDF文档。本文将通过C#代码演示具体加密及解密方法。

具体步骤:

步骤一dll文件获取及导入。通过下载文件包,并将Spire.Cloud.Pdf.Sdk.dll文件及其依赖项dll添加引用至VS程序;或通过Nuget下载安装。可参考这篇文章里dll文件添加引用方法。

步骤二App ID及Key获取。在云端创建账号,并在“我的应用”板块中创建应用以获得App ID及App Key。

Spire.Cloud.PDF 加密、解密 PDF 文档

步骤三源文档上传。在“文档管理”板块,上传源文档。这里可以建文件夹,将文档存放在文件夹下。不建文件夹时,源文档及结果文档直接保存在根目录。本文示例中,建了两个文件夹,分别用于存放源文档及结果文档。(云平台提供免费1 万次调用次数和 2G 文档内存)

Spire.Cloud.PDF 加密、解密 PDF 文档

加密PDF文档

using System;
using Spire.Cloud.Pdf.Sdk.Client;
using Spire.Cloud.Pdf.Sdk.Api;
using System.IO;
using System.Collections.Generic;

namespace Encryt
{
    class Program
    {
        static String appID = "App ID";
        static String appKey = "App Key";
        static void Main(string[] args)
        {
            //配置账号信息
            Configuration pdfConfiguration = new Configuration(appID,appKey);
            PdfSecurityApi pdfSecurityApi = new PdfSecurityApi(pdfConfiguration);

            string name = "sample.pdf";//源文档
            string outPath = "pdfsecurity/Encrypt.pdf";//结果文档路径(将结果文档存放在pdfsecurity文件夹下)
            string userPassword = ToBase64String("123");//用户密码     
            string ownerPassword = ToBase64String("321");//所有者密码
            string keySize = "Key40Bit";//设置keySize(如果不需要设置,可设置为null)
            List permissionsFlags = new List();//设置permissionsFlags(如果不需要设置,可设置为null)
            permissionsFlags.Add("Print");
            string folder = "input";//源文档所在文件夹
            string password = null;//源文档密码

            //调用方法加密文档
           pdfSecurityApi.EncryptDocumentInStorage(name,outPath,userPassword,ownerPassword,keySize,permissionsFlags,folder,password);

        }
        private static string ToBase64String(string value)
        {
            byte[] b = System.Text.Encoding.UTF8.GetBytes(value);
            string base64String = Convert.ToBase64String(b);
            base64String = base64String.Replace("+", "%2B");
            return base64String;
        }
    }
}

生成的文档打开时,需要输入密码。

文档加密结果:

Spire.Cloud.PDF 加密、解密 PDF 文档

解密PDF文档

这里以上文中生成的加密PDF为测试文档。

using System;
using Spire.Cloud.Pdf.Sdk.Client;
using Spire.Cloud.Pdf.Sdk.Api;

namespace Decrypt
{
    class Program
    {
        static String appID = "App ID";
        static String appKey = "App Key";
        static void Main(string[] args)
        {
            //配置账号信息
            Configuration pdfConfiguration = new Configuration(appID, appKey);
            PdfSecurityApi pdfSecurityApi = new PdfSecurityApi(pdfConfiguration);

            string name = "Encrypt.pdf";//源文档
            string outPath = "pdfsecurity/Decrypt.pdf";//结果文档路径(pdfsecurity为结果文档所在文件夹)
            string password = ToBase64String("321");//文档密码(这里需要使用ownerpassword)
            string folder = "pdfsecurity";//源文档所在文件夹

            //调用方法解密文档
            pdfSecurityApi.DecryptDocumentInStorage(name,outPath,password,folder);
        }
        private static string ToBase64String(string value)
        {
            byte[] b = System.Text.Encoding.UTF8.GetBytes(value);
            string base64String = Convert.ToBase64String(b);
            base64String = base64String.Replace("+", "%2B");
            return base64String;
        }
    }
}

生成的文档将不再有密码保护。