Spire.Cloud.PDF.SDK 提供了接口 PdfSecurityApi 可用于加密、解密 PDF 文档。本文将通过 C# 代码演示具体加密及解密方法。
具体步骤:
步骤一:dll 文件获取及导入。通过下载文件包,并将 Spire.Cloud.Pdf.Sdk.dll 文件及其依赖项 dll 添加引用至 VS 程序;或通过 Nuget 下载安装。可参考这篇文章里 dll 文件添加引用方法。
步骤二:App ID 及 Key 获取。在云端创建账号,并在“我的应用”板块中创建应用以获得 App ID 及 App Key。
步骤三:源文档上传。在“文档管理”板块,上传源文档。这里可以建文件夹,将文档存放在文件夹下。不建文件夹时,源文档及结果文档直接保存在根目录。本文示例中,建了两个文件夹,分别用于存放源文档及结果文档。(云平台提供免费1 万次调用次数和 2G 文档内存)
加密 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;
}
}
}
生成的文档打开时,需要输入密码。
文档加密结果:
解密 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;
}
}
}
生成的文档将不再有密码保护。