0

我正在尝试使用 django pisa 模块生成 PDF。

视图.py

def reportPdf(template_src, context_dict):

        template = get_template(template_src)
        context = Context(context_dict)
        htmlRender = template.render(context)
        resultObj = StringIO.StringIO()
        pdfObject = pisa.pisaDocument(StringIO.StringIO(htmlRender.encode(
            'utf-8')), resultObj,link_callback=fetch_resources)
        response = HttpResponse(resultObj.getvalue(), content_type = 'application/pdf')
        response["Content-Disposition"] = 'inline;filename=sample.PDF'
        return response
 def fetch_resources(uri, rel):
         import project.settings
         path = os.path.join(project.settings.MEDIA_ROOT, uri.replace(
                                            project.settings.MEDIA_URL, ""))
         return path

class abc():
     def get(self,request, *args, **kwargs):
     // some code
     return reportPdf('pdf.djhtml',{'pagesize': 'A4',"refer_data":detail}

设置.py:

PROJECT_PATH = os.path.realpath(os.path.dirname(__file__))
MEDIA_ROOT = os.path.realpath(os.path.join(PROJECT_PATH, "media"))
MEDIA_URL = '/media/'

模板:

pdf.djhtml:媒体文件夹中可用的图像代码:

<img src="/media/sample.jpg"/>

以上工作正常,因为我已将媒体合并到 views.py

但下面的代码不会加载图像。

refer_data.image.url = http://www.w3schools.com/images/w3schools_green.jpg(将此 http url 视为测试示例)。我从 API 调用中获取的此图像 url。

 {% if refer_data.image.url != "" %}
        <img src="{{refer_data.image.url}}"/>
 {% else %}
       <img src="noimage.png"/>

 {% endif %}

有人可以分析并分享我在哪里失踪的想法吗?任何帮助将不胜感激。

4

1 回答 1

0

您可以检查您是在处理本地还是绝对 HTTP URL ,这是使用验证器fetch_resources的示例:

import project.settings
import validators

def fetch_resources(uri, rel):
    if validators.url(uri):
      return uri
    else:
      path = os.path.join(project.settings.MEDIA_ROOT, uri.replace(
                                            project.settings.MEDIA_URL, ""))
      return path

对于绝对 url ( http://www.google.com) 返回 url,否则对于相对 url/media/myimage.jpg它返回连接的媒体路径。

于 2016-11-21T16:40:20.427 回答