正如@YuriyGalanter所指出的,PDF中的限制性权限主要是在PDF加密的上下文中定义的,参见PDF规范的第7.6.3.1节ISO 32000-1:2008:
如果指定了密码或访问限制,则应对文档进行加密,并且验证密码所需的权限和信息应存储在加密字典中 . 仅加密文件附件的文档应使用与用户和所有者密码相同的密码 . 使用正确的所有者密码打开文档应允许完全(所有者)访问文档 . 这种无限制访问包括更改文档密码和访问权限的功能 . 使用正确的用户密码打开文档(或使用默认密码打开文档)应允许根据文档加密字典中指定的用户访问权限执行其他操作 .
因此,如果使用所有者密码但没有用户密码对PDF进行加密,则任何人都可以打开PDF并受加密期间选择的权限限制 . 只允许以其所有者密码打开该PDF的人才能无限制地访问PDF .
显然,这样的方案很容易被打破并且保护被删除 . 这取决于PDF处理软件的道德行为 .
方法 createPdf 说明了在创建新PDF时如何应用加密:
public void createPdf(String filename) throws IOException, DocumentException {
// step 1
Document document = new Document();
// step 2
PdfWriter writer = PdfWriter.getInstance(document, new FileOutputStream(filename));
writer.setEncryption(USER, OWNER, PdfWriter.ALLOW_PRINTING, PdfWriter.STANDARD_ENCRYPTION_128);
writer.createXmpMetadata();
// step 3
document.open();
// step 4
document.add(new Paragraph("Hello World"));
// step 5
document.close();
}
方法 encryptPdf 说明了如何加密现有PDF:
public void encryptPdf(String src, String dest) throws IOException, DocumentException {
PdfReader reader = new PdfReader(src);
PdfStamper stamper = new PdfStamper(reader, new FileOutputStream(dest));
stamper.setEncryption(USER, OWNER,
PdfWriter.ALLOW_PRINTING, PdfWriter.ENCRYPTION_AES_128 | PdfWriter.DO_NOT_ENCRYPT_METADATA);
stamper.close();
reader.close();
}
这里 USER 和 OWNER 是上面提到的用户和所有者密码 .
该示例仅设置一个权限, PdfWriter.ALLOW_PRINTING ;还有其他多个,只需检查 PdfWriter. 的所有 ALLOW_* 常量