我正在使用wkhtmltopdf
将HTML文档转换为我们网站上的PDF文件.我在我的PHP类中使用以下代码:
<?PHP
$pdfConv = proc_open('wkhtmltopdf -q -s letter --no-background --print-media-type --title Test - -', [
0 => array('pipe', 'r'),
1 => array('pipe', 'w'),
2 => array('pipe', 'w')
], $pipes, '/tmp', NULL, [
'bypass_shell' => true
]);
if(is_resource($pdfConv)){
// Send STDIN
fwrite($pipes[0], $htmlData);
fclose($pipes[0]);
// Receive STDOUT
$pdfFile = stream_get_contents($pipes[1]);
fclose($pipes[1]);
// Set headers and send file to browser to be downloaded
// Close process
proc_close($pdfConv);
}
注意:出于测试目的,我执行了$htmlData = file_get_contents(‘http://google.com’);.
当我在浏览器中浏览页面并单击“下载PDF”时,我得到以下输出:
试图找出错误的原因,我接受了命令行并运行:
wkhtmltopdf -q -s letter --no-background --print-media-type --title Test http://google.com /tmp/google.pdf
这非常有效,所以我想知道PHP是否有问题.我键入了PHP -a并将上面的代码粘贴到命令行中并运行它,它运行得很好.
这是PDF应该是什么样子:
为什么从Apache运行相同的代码(通过我的Web浏览器)提供的PDF不同于直接在命令行上运行?这些奇怪的角色来自哪里?我怎么能调试这个?
解决方法:
多亏了@Havenard,我发现了问题所在.我从命令行运行导出,并通过PHP中的proc_open运行并比较输出.
在我的命令行中,我看到LANG = en_US.UTF8但是从PHP它说LANG =“C”.
解决方案是在proc_open中设置环境中的LANG值
$pdfConv = proc_open('wkhtmltopdf -q -s letter --no-background --print-media-type --title Test - -', [
0 => array('pipe', 'r'),
1 => array('pipe', 'w'),
2 => array('pipe', 'w')
], $pipes, '/tmp', [
'LANG' => 'en_US.UTF8'
], [
'bypass_shell' => true
]);