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;
}
}
}
生成的文档将不再有密码保护。