个性化阅读
专注于IT技术分析

如何在PHP中加密由TCPDF生成的PDF(密码保护)

点击下载

本文概述

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 Viewer中受密码保护的PDF

上一张图片显示了一个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类的文档。玩得开心!

赞(1)
未经允许不得转载:srcmini » 如何在PHP中加密由TCPDF生成的PDF(密码保护)

评论 抢沙发

评论前必须登录!