Изображение не отображается, когда я хочу получить его из базы данных: Django -xhtml2pdf

Мне нужно получить изображение из базы данных (введенное мной в интерфейсе Django-admin), и отобразить его в сгенерированном pdf.

Сначала я получаю изображение для каждого конкретного пользователя, вошедшего в систему, вот так в views.py:

image1_full = CustomerPersonalData.objects.get(user_related=request.user)
obj_image1 = CustomerPersonalData._meta.get_field('image1')
value_image1 = str(obj_image1.value_from_object(image1_full)) 

в pdf_generated.html я определил его следующим образом:

<img src={{value_image1.url}} />

----> но при этом не отображается изображение.

PS: я использую xhtml2pdf

Добро пожаловать в SO.

Вот как я смог успешно реализовать это. Надеюсь, это поможет

url.py

path('foo/bar/<str:bar_id>/report/pdf/', getPdf,name="bar-report-pdf"),

process.py

from io import BytesIO
from django.conf import settings
from django.http import HttpResponse
from django.template.loader import get_template
from xhtml2pdf import pisa

def html_to_pdf(template_src, context_dict={}):
    template = get_template(template_src)
    html  = template.render(context_dict)

    result = BytesIO()
    pdf = pisa.pisaDocument(BytesIO(html.encode("ISO-8859-1")), 
                            result,
                            )
    if not pdf.err:
        return HttpResponse(result.getvalue(), content_type='application/pdf')
    return None

не используйте атрибут link_callback в pisaDocument при использовании внешних url

view.py

from foo.process import html_to_pdf 

def getPdf(request,bar_id):

    image_set = Bar.objects.filter(id=bar_id).all()
    
    context = {
        'title':"Inspection Report",
        "images": image_set,
        }

    open('templates/temp.html', "w").write(render_to_string('app/bar-report-pdf.html',context ))

    pdf = html_to_pdf('temp.html')
         
    return HttpResponse(pdf, content_type='application/pdf')

bar-report-pdf.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    {% for image in images %}
            <img class="d-block img-fluid" src="{{image.thumbnail_url_public}}" alt="{{forloop.counter}}">
    {% endfor %}
</body>
</html>

здесь image.thumbnail_url_public находится текстовое поле, содержащее публичный url изображения s3. Вы также можете использовать предварительно подписанный url, если это частное ведро s3.

надеюсь, это поможет

У меня была та же проблема, и после многократных попыток решения с кодировкой base64 самым простым решением было заменить .url на .path, что работало на моем windows dev-сервере и linux production-сервере

<img src="{{value_image1.path}}" />
Вернуться на верх