你好我在搜索这个问题之前经常搜索。 我知道签署pdf setasign.com
有一个备用选项我尝试使用php函数:
openssl_pkcs7_sign( FULL_PATH . "/pdforiginal.pdf", //ORIGIANL PDF
FULL_PATH ."signedPDF.pdf", // SIGNED PDF
"file://" . FULL_PATH . "signing_cert.pem",
array( "file://" . FULL_PATH. "private_key.pem",""),array());
signing_cert.pem< - //我不明白这是什么我只有private_key和public_key。我看到一些人们在这里使用private_key的例子。
我的私钥没有密码,我使用空白“”或空?
如果有人能给我一些关于这个主题的信息会非常有帮助。
答案 0 :(得分:3)
我找到了解决方案。 我使用FPDI库打开pdf并使用tcpdf库对其进行签名。 这使得这个过程非常简单。
require_once('tcpdf_include.php');
require_once "fpdi.php";
$pdf = new FPDI('P', 'mm', 'A4'); //FPDI extends TCPDF
$pages = $pdf->setSourceFile('document.pdf');
/*
NOTES:
- To create self-signed signature: openssl req -x509 -nodes -days 365000 -newkey rsa:1024 -keyout tcpdf.crt -out tcpdf.crt
- To export crt to p12: openssl pkcs12 -export -in tcpdf.crt -out tcpdf.p12
- To convert pfx certificate to pem: openssl pkcs12 -in tcpdf.pfx -out tcpdf.crt -nodes
*/
$certificate = 'file://data/cert/tcpdf.crt';
// set additional information
$info = array(
'Name' => 'TCPDF',
'Location' => 'Office',
'Reason' => 'Testing TCPDF',
'ContactInfo' => 'http://www.tcpdf.org',
);
for ($i = 1; $i <= $pages; $i++)
{
$pdf->AddPage();
$page = $pdf->importPage($i);
$pdf->useTemplate($page, 0, 0);
// set document signature
$pdf->setSignature($certificate, $certificate, 'tcpdfdemo', '', 2, $info);
}
答案 1 :(得分:0)
现在正在加密设备上发布数字证书,即。 USB 令牌和智能卡,用户将持有相同的,服务器可能没有用户证书的私钥。在 Web 应用程序中,您需要从连接到客户端(浏览器)设备的 USB 令牌或智能卡获取 pdf(哈希)签名。
您需要从浏览器本身获得 pdf 签名,因为私钥永远不会来自 USB 令牌。请参考答案https://stackoverflow.com/a/55676351/9659885
对于 PHP,可以通过运行在 Tomcat 上的 JavaBridge 通过 Apache 代理使用易于获得的 Java pdf 库或任何 pdf 组件,从浏览器 USB 令牌和服务器端的 PHP 对 PDF 进行数字签名。
答案 2 :(得分:0)
我找到了更好的签名解决方案,但不仅限于 PHP。您需要使用 exec() 命令来执行此操作。
1 - 需要安装 java。 Linux sudo apt install /select_folder/default-jre
2 - 需要安装便携式签名器。下载 ZIP 文件并运行文件 jar ( https://sourceforge.net/projects/portablesigner/files/portablesigner/2.0-Release/PortableSigner-Generic-2.0.38c0573.zip/download )。 Linux sudo java -jar /select_folder/PortableSigner.jar
3 - 安装 Portable Signer 并选择安装文件夹后,使用手册 (http://portablesigner.sourceforge.net/) 和 php 中的命令 exec() 执行应用程序。
示例: exec("java -jar PortableSigner.jar -n /Users/pfp/Desktop/unsigned.pdf -o /Users/pfp/Desktop/signed.pdf -s /Users/pfp/Desktop/certificate.pfx -p MySecretPassword");
在文档中,您有许多签名选项。我希望这会对这里的 PHP 社区有很大帮助。