本文概述
PDF是数字世界中最接近正式文档的文件, 并且在现实生活中, 某些PDF旨在以保密的方式进行保密。而且, 如果你想使用TCPDF保护生成的PDF, 则库中内置了对密码保护和加密的支持, 你只需要学习如何使用它即可。
基本上, 保护文档所需要做的就是使用$ yourPDF-> SetProtection($ arguments)方法。
注意:保护文档需要对其进行加密, 这大大增加了处理时间。在某些情况下, 这可能会导致PHP超时, 尤其是在文档包含图像或字体的情况下。你可以使用set_time_limit($ seconds)延长执行时间, 以增加时间限制, 或者更改php.ini文件中的值。
关于SetProtection方法
SetProtection方法最多需要5个参数:
1.权限数组
第一个参数是一个字符串数组, 其标识符为内容, 该内容指示应从PDF中删除哪些权限。
- 打印:禁用从任何PDF查看器打印PDF的可能性。
- 修改:防止通过除”填写表格”, “提取”和”汇编”所控制的操作之外的其他操作来修改文档的内容;
- 复制:防止复制或从文档中提取文本和图形;
- annot-forms:添加或修改文本注释, 填写交互式表单字段, 如果还设置了”修改”, 则创建或修改交互式表单字段(包括签名字段);
- fill-forms:即使未指定” annot-forms”, 也要填写现有的交互式表单字段(包括签名字段);
- 提取:提取文本和图形(以支持残障用户使用或出于其他目的);
- 组装:即使未设置”修改”, 也可以组装文档(插入, 旋转或删除页面并创建书签或缩略图图像);
- 高打印:将文档打印到一个表示形式, 可以从该表示形式生成PDF内容的忠实数字副本。如果未设置此选项, 则打印仅限于外观的低级表示, 可能会降低质量。
- owner :(反逻辑-仅用于公共密钥)设置时, 允许更改加密并启用所有其他权限。
以下代码应防止打印或修改PDF:
$pdf->SetProtection(array('print', 'modify'));
2.用户密码
第二个参数是每个用户每次尝试在任何PDF查看器中打开PDF时应提供的密码。使用null或”作为值不使用该用户的任何密码。
上一张图片显示了一个PDF, 其密码尝试在Chrome PDF Viewer中查看。
3.所有者密码
如果要撤消任何PDF查看器中的任何已删除权限, 则主(所有者)密码(与用户密码不同)可用于获得完整的文档访问权限。
4.加密类型
加密类型的可能值为:
- 0 = RSA 40位
- 1 = RSA 128位
- 2 = AES 128位
- 3 = AES 256位
PDF加密内部使用40、128或256位的加密密钥, 具体取决于PDF版本。二进制加密密钥源自用户提供的密码。
RSA 40位的加密PDF应该使用以下方式创建:
$pdf->SetProtection($permissions, "PasswordForUsers", "MyMasterPassword", 0);
5.用公钥签名pdf
如果要使用公共密钥对PDF进行签名, 则需要提供一个带有2个密钥的数组作为第五个参数和最后一个参数:
- c:证书的本地路径(yourpublickey.crt)。
- p:数组中的权限(与第一个参数相同的结构)。
使用公钥签名的PDF应该使用以下代码创建:
$pdf->SetProtection(null, null, null, 0, array(
'c' => '/path/to/self-signed-certificate.crt', 'p' => array('print', 'modify')
));
受保护的PDF的示例
如前所述, 为了保护你的PDF, 你需要注意SetProtection方法, 你可以开始使用。
<?php
//require __DIR__ . '/vendor/autoload.php';
// we supposed that you know how to include the TCPDF class in your document
$pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);
/**
* Protect PDF from being printed, copied or modified. In order to being viewed, the user needs
* to provide "ourcodeworld" as password.
*/
$pdf->SetProtection(array('print', 'copy', 'modify'), "ourcodeworld", "ourcodeworld-master", 0, null);
// set document information
$pdf->SetCreator(PDF_CREATOR);
$pdf->SetAuthor('Our Code World');
$pdf->SetTitle('TCPDF Example');
$pdf->SetSubject('TCPDF Tutorial');
$pdf->SetKeywords('TCPDF, PDF, example, test, guide');
// set default header data
$pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE.' 016', PDF_HEADER_STRING);
// set header and footer fonts
$pdf->setHeaderFont(array('helvetica', '', PDF_FONT_SIZE_MAIN));
$pdf->setFooterFont(array('helvetica', '', PDF_FONT_SIZE_DATA));
// set default monospaced font
$pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
// set margins
$pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
$pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
$pdf->SetFooterMargin(PDF_MARGIN_FOOTER);
// set auto page breaks
$pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);
// set image scale factor
$pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);
// add a page
$pdf->AddPage();
// set some text to print
$txt = <<<EOD
Encryption Example
Consult the source code documentation for the SetProtection() method.
EOD;
// print a block of text using Write()
$pdf->Write(0, $txt, '', 0, 'L', true, 0, false, false, 0);
//Close and output PDF document to the browser
$pdf->Output('example_016.pdf', 'I');
你可以在TCPDF网站上查看有关PDF加密的官方演示, 或阅读TCPDF类的文档。玩得开心!
评论前必须登录!
注册