Django - wkhmltopdf - CalledProcessError(仅适用于命令行中的 sudo)
Django - wkhmltopdf - CalledProcessError (only works with sudo from command line)
我正在尝试使用 django-wkhtmltopdf
从 Django 模板呈现 PDF。问题是 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
我还注意到 /tmp/
文件夹中的一些临时 html
文件没有被删除。
这是一个完整的回溯 Django returns:
回溯:
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
版本,但没有帮助。
我唯一的想法是运行 wkhtmltopdf
的 user
没有 /tmp/
的权限,但我不知道。
编辑 - 视图
class PDFAgreementView(PDFTemplateView):
template_name = 'agreements/pdf_template.html'
filename = 'rendered.pdf'
在这种情况下,答案很简单但很难调试:
我在 settings.py
中进行了一些设置:
WKHTMLTOPDF_CMD_OPTIONS = {
'quiet': True,
}
然后,我改成了:
WKHTMLTOPDF_CMD_OPTIONS = {
'quiet': False,
}
默认情况下是 False
,当您明确指定它时会导致错误。
感谢 chidg:
如果您的 macOs 版本是 Big Sur。将以下内容添加到您的 settings.py 文件
WKHTMLTOPDF_CMD_OPTIONS = {
'enable-local-file-access': True,
}
我正在尝试使用 django-wkhtmltopdf
从 Django 模板呈现 PDF。问题是 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
我还注意到 /tmp/
文件夹中的一些临时 html
文件没有被删除。
这是一个完整的回溯 Django returns:
回溯:
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
版本,但没有帮助。
我唯一的想法是运行 wkhtmltopdf
的 user
没有 /tmp/
的权限,但我不知道。
编辑 - 视图
class PDFAgreementView(PDFTemplateView):
template_name = 'agreements/pdf_template.html'
filename = 'rendered.pdf'
在这种情况下,答案很简单但很难调试:
我在 settings.py
中进行了一些设置:
WKHTMLTOPDF_CMD_OPTIONS = {
'quiet': True,
}
然后,我改成了:
WKHTMLTOPDF_CMD_OPTIONS = {
'quiet': False,
}
默认情况下是 False
,当您明确指定它时会导致错误。
感谢 chidg:
如果您的 macOs 版本是 Big Sur。将以下内容添加到您的 settings.py 文件
WKHTMLTOPDF_CMD_OPTIONS = {
'enable-local-file-access': True,
}