php – 在apache日志中出现wkhtmltopdf错误

exec("wkhtmltopdf test.html output.pdf");

在php命令行中它可以工作,但如果我尝试从apache调用它,它不会创建pdf文件,日志显示:

$tail -f  /var/log/apache2/error.log
wkhtmltopdf: cannot connect to X server

解决方法:

您可以使用Xvfb来模拟x环境

<?php exec("xvfb-run -a wkhtmltopdf test.html output.pdf");

要么

<?php exec("startx -- `which Xvfb` :1 -screen 0 800x600x24 && DISPLAY=:1 && wkhtmltopdf test.html output.pdf");

我为自己创建了这个脚本,以便在centos 6上运行wkhtml:

 yum install xorg-x11-server-Xvfb
    nano /etc/init.d/xvfbd
    #paste this:
    #!/bin/bash

#
# /etc/rc.d/init.d/xvfbd
#
# chkconfig: 345 95 28
# description: Starts/Stops X Virtual Framebuffer server
# processname: Xvfb
#

. /etc/init.d/functions

[ "${NETWORKING}" = "no" ] && exit 0

PROG="/usr/bin/Xvfb"
PROG_OPTIONS=":1 -screen 1 1024x768x24 -nolisten tcp"
PROG_OUTPUT="/tmp/Xvfb.out"

case "$1" in
start)
echo -n "Starting : X Virtual Frame Buffer "
$PROG $PROG_OPTIONS>>$PROG_OUTPUT 2>&1 &
disown -ar
/bin/usleep 500000
status Xvfb & >/dev/null && echo_success || echo_failure
RETVAL=$?
if [ $RETVAL -eq 0 ]; then
/bin/touch /var/lock/subsys/Xvfb
/sbin/pidof -o %PPID -x Xvfb > /var/run/Xvfb.pid
fi
echo
;;
stop)
echo -n "Shutting down : X Virtual Frame Buffer"
killproc $PROG
RETVAL=$?
[ $RETVAL -eq 0 ] && /bin/rm -f /var/lock/subsys/Xvfb
/var/run/Xvfb.pid
echo
;;
restart|reload)
$0 stop
$0 start
RETVAL=$?
;;
status)
status Xvfb
RETVAL=$?
;;
*)
echo $"Usage: $0 (start|stop|restart|reload|status)"
exit 1
esac

exit $RETVAL


#END
chmod 550 /etc/init.d/xvfbd
chkconfig xvfdb on
service xvfdb start

#Compile wkhtml compelety:
http://code.google.com/p/wkhtmltopdf/wiki/compilation

./configure -nomake examples,demos,docs,translations -opensource -webkit -prefix "../wkqt"


#Install fonts:
yum install xorg-x11-fonts*

之后在PHP中运行它:

exec("DISPLAY=:1  timeout 60 wkhtmltoimage --height 1024 --width 1280 --quality 80 \"" . $site . "\" " . $filename);
上一篇:从PHP执行wkhtmltopdf失败


下一篇:php – 如何在现有PDF上叠加HTML生成的PDF?