0

我正在尝试使用django-wkhtmltopdf. 问题是wkhtmltopdf开始提出:

Command '['/usr/bin/wkhtmltopdf', '--encoding', u'utf8', '--quiet', u'False', '/tmp/wkhtmltopdfRDyi61.html', '-']' returned non-zero exit status 1

无法弄清楚问题出在哪里,但我注意到我什至无法在命令行中执行(我在 virtualenv 中):

wkhtmltopdf http://www.google.com g.pdf

Loading pages (1/6)
QPainter::begin(): Returned false============================] 100%
Error: Unable to write to destination                              
Exit with code 1, due to unknown error.

它仅适用于sudo特权(但我在 PyCharmProject 我的用户目录中):

sudo wkhtmltopdf http://www.google.com g.pdf

我还注意到文件夹中的一些临时html文件/tmp/没有被删除。

这是 Django 返回的完整回溯:

追溯:

Environment:


Request Method: GET
Request URL: http://127.0.0.1:8000/render/

Django Version: 1.11.7
Python Version: 2.7.12
Installed Applications:
['django.contrib.admin',
 'django.contrib.auth',
 'django.contrib.contenttypes',
 'django.contrib.sessions',
 'django.contrib.messages',
 'django.contrib.staticfiles',
 'agreements',
 'weasyprint']
Installed Middleware:
['django.middleware.security.SecurityMiddleware',
 'django.contrib.sessions.middleware.SessionMiddleware',
 'django.middleware.common.CommonMiddleware',
 'django.middleware.csrf.CsrfViewMiddleware',
 'django.contrib.auth.middleware.AuthenticationMiddleware',
 'django.contrib.messages.middleware.MessageMiddleware',
 'django.middleware.clickjacking.XFrameOptionsMiddleware']



Traceback:

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/django/core/handlers/exception.py" in inner
      41.             response = get_response(request)

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/django/core/handlers/base.py" in _get_response
      217.                 response = self.process_exception_by_middleware(e, request)

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/django/core/handlers/base.py" in _get_response
      215.                 response = response.render()

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/django/template/response.py" in render
      107.             self.content = self.rendered_content

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/wkhtmltopdf/views.py" in rendered_content
      78.             cmd_options=cmd_options

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/wkhtmltopdf/utils.py" in render_pdf_from_template
      186.                           cmd_options=cmd_options)

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/wkhtmltopdf/utils.py" in convert_to_pdf
      124.     return wkhtmltopdf(pages=filename, **cmd_options)

    File "/home/milano/.virtualenvs/maklerienv/local/lib/python2.7/site-packages/wkhtmltopdf/utils.py" in wkhtmltopdf
      110.     return check_output(ck_args, **ck_kwargs)

    File "/usr/lib/python2.7/subprocess.py" in check_output
      574.         raise CalledProcessError(retcode, cmd, output=output)

    Exception Type: CalledProcessError at /render/
    Exception Value: Command '['/usr/bin/wkhtmltopdf', '--encoding', u'utf8', '--quiet', u'False', '/tmp/wkhtmltopdfRDyi61.html', '-']' returned non-zero exit status 1

你有什么想法?我尝试安装最新wkhtmltopdf版本,但没有帮助。

我唯一的想法是user运行wkhtmltopdf没有特权,/tmp/但我不知道。

编辑 - 视图

class PDFAgreementView(PDFTemplateView):
    template_name = 'agreements/pdf_template.html'
    filename = 'rendered.pdf'
4

2 回答 2

0

如果您的 macOS 版本是 Big Sur。将以下内容添加到您的 settings.py 文件中

WKHTMLTOPDF_CMD_OPTIONS = {
    'enable-local-file-access': True,
}
于 2021-01-20T16:32:42.157 回答
0

在这种情况下,答案很简单但很难调试:

我有一些设置settings.py

WKHTMLTOPDF_CMD_OPTIONS = {
     'quiet': True,
}

然后,我将其更改为:

WKHTMLTOPDF_CMD_OPTIONS = {
     'quiet': False,
}

默认False情况下,当您明确指定它时会导致错误。

感谢chidg

嗨,尝试从您的选项中删除 'quiet': False。quiet选项默认为false,所以只需要在设置为true的情况下指定该选项,而这个选项字典到命令行选项的映射导致在命令中传入--quiet False,这是不正确的句法。

于 2017-11-29T11:50:21.427 回答