Django GeneratePDF с xhtml2pdf - метод не разрешен (GET)
Я бы изменил следующий класс GeneratePDF для рендеринга моего шаблона, который генерируется динамически
В myproject / myapp /utils.py
from io import BytesIO
from django.http import HttpResponse
from django.template.loader import get_template
from xhtml2pdf import pisa
def render_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
views.py
class GeneratePDF(View):
def get(self, request, *args, **kwargs):
template = get_template('invoice.html')
context = {
"invoice_id": 123,
"customer_name": "John Cooper",
"amount": 1399.99,
"today": "Today",
}
html = template.render(context)
pdf = render_to_pdf('invoice.html', context)
if pdf:
response = HttpResponse(pdf, content_type='application/pdf')
filename = "Invoice_%s.pdf" %("123")
content = "inline; filename='%s'" %(filename)
download = request.GET.get("download")
if download:
content = "attachment; filename='%s'" %(filename)
response['Content-Disposition'] = content
return response
return HttpResponse("Not found")
Я генерирую свой шаблон со следующим:
class MyReport(ListView):
model = Reports
template_name = 'myreports.html'
context_object_name = 'myreports'
def get_context_data(self, *args,**kwargs):
context = super(MyReport, self).get_context_data(*args,**kwargs)
context['reports'] = Reports.objects.all().values('id','idsys','itemcode','ordercode').filter(id=self.kwargs['id'],idsys=self.kwargs['idsys'])
return context
и я пытаюсь сгенерировать PDF со следующим измененным классом:
class GeneratePDF(View):
def get_context_data(self, *args,**kwargs):
template = get_template('myreports.html')
context = super(GeneratePDF, self).get_context_data(*args,**kwargs)
context['reports'] = Reports.objects.all().values('id','idsys','itemcode','ordercode').filter(id=self.kwargs['id'],idsys=self.kwargs['idsys'])
html = template.render(context)
pdf = render_to_pdf('myreports.html', context)
if pdf:
response = HttpResponse(pdf, content_type='application/pdf')
filename = "myreports_%s.pdf" %("1")
content = "inline; filename='%s'" %(filename)
download = request.GET.get("download")
if download:
content = "attachment; filename='%s'" %(filename)
response['Content-Disposition'] = content
return response
return HttpResponse("Not found")
urls.py
url(r'^reports_pdf/(?P<id>\d+)/(?P<idsys>\d+)/$', views.GeneratePDF.as_view())
но я получаю ошибку: метод не разрешен (GET) Есть ли у вас какие-либо предложения? Спасибо
(Я следовал за этим: Render_to_PDF_in_Django)
1 ответ
Вы получаете эту ошибку, потому что вы унаследовали от View
класс, который не реализован get()
метод по умолчанию. Это означает, что ваш взгляд не знает, что делать с GET
запросить и поднять ошибку. Для решения проблемы необходимо определить get()
метод для GeneratePDF
учебный класс. Только после этого GeneratePDF
сможет справиться GET
Запросы. Также View
класс не обеспечивает get_context_data
метод, вы можете удалить это context = super(GeneratePDF, self).get_context_data(*args,**kwargs)
и заменить его простым определением контекста как пустой словарь context={}
:
class GeneratePDF(View):
def get(self, *args,**kwargs):
template = get_template('myreports.html')
context = {}
context['reports'] = Reports.objects.all().values('id','idsys','itemcode','ordercode').filter(id=self.kwargs['id'],idsys=self.kwargs['idsys'])
html = template.render(context)
pdf = render_to_pdf('myreports.html', context)
if pdf:
response = HttpResponse(pdf, content_type='application/pdf')
filename = "myreports_%s.pdf" %("1")
content = "inline; filename='%s'" %(filename)
download = request.GET.get("download")
if download:
content = "attachment; filename='%s'" %(filename)
response['Content-Disposition'] = content
return response
return HttpResponse("Not found")