javascript - jquery ajax不提供pdf文件

标签 javascript jquery ajax django pdf

我正在尝试使用 jquery、ajax 和 django 下载 pdf 文件。

我的 Django View .py:

if request.POST.get('action') == 'download_labels':
    order_list = json.loads(request.POST.get('order_dict'), None)
    PackedOrders(dbname, order_list).downloadLabels()
    file = open('shipping_labels.pdf','rb')
    response = HttpResponse(file, content_type='application/pdf')
    response['Content-Disposition'] = "attachment; filename=shipping_labels.pdf"
    os.system('rm shipping_labels.pdf')
    return HttpResponse(response, content_type='application/pdf')

我的ajax查询:

data : {action:'download_labels',
        order_dict:JSON.stringify($checkedRows)},

success : function(response, status, request) {
    var file = new Blob([response], {type: 'application/pdf'});
    var fileURL = window.URL.createObjectURL(file);
    window.open(fileURL,'_blank');
},

ajax 将文件作为二进制数据响应返回,并在新选项卡中打开它。但我在新选项卡中看到的只是空白页面。空白页数等于原始 pdf 文件的页数。

在控制台中我看到这个:

Error: Invalid XRef stream header
...
Warning: Indexing all PDF objects
pdf.worker.js (line 235)
<System>
PDF 85b859244e496561d60d217869d5d38a [1.3 - / -] (PDF.js: 1.3.76)
Error: Bad FCHECK in flate stream: 120, 239
...

Here是完整的日志文件。

最佳答案

我不是 jQuery 专家,但我不认为 jQuery ajax 支持 blob。在文档中,它仅列出了这些数据类型:xml、json、script 或 html。 然而,我能够在不使用 jQuery 的情况下使用此功能,并使用带有纯 JavaScript 的 ajax 和此代码,

我的 JavaScript(我还会为此添加错误处理)

var xhr = new XMLHttpRequest();
xhr.open('GET', '/pdf_test', true);
xhr.responseType = 'blob';

xhr.onload = function(e) {
  if (this.status == 200) {
    var blob = new Blob([this.response], {type: 'application/pdf'}),
    fileURL = URL.createObjectURL(blob);
    window.open(fileURL,'_blank');
  }
};

xhr.send();

我的 django View (我还会为此添加错误处理)

def pdf_test(request):
    pdf_file = open(r'C:\Pdfs\calculation_of_semiconductor_failure_rates.pdf', 'rb')
    response = HttpResponse(pdf_file, content_type='application/pdf')
    response['Content-Disposition'] = 'attachment; filename="shippinglabels.pdf"'
    return response

除此之外,如果您不需要在新选项卡中打开而只需下载文件,那么您可以完全避免使用ajax/Javascript,而只使用 HTML,这是一种更简单的方法

<a id="pdf-test" href="/pdf_test">Download PDF</a>

为了获得学分和进一步阅读,我使用了这些链接

jQuery Ajax

StackOverflow question

Introduction to JavaScript Blobs and File Interface

关于javascript - jquery ajax不提供pdf文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37942573/

相关文章:

javascript - (function(window){}) 和 (function(){}) 之间的区别

javascript 使用片段刷新当前页面

javascript - LARAVEL中使用JS Array通过AJAX动态插入HTML到View中

c# - Telerik Grid中ajax绑定(bind)数据时如何进行分组和聚合

java - JQuery 无响应脚本错误

javascript - IFrame 到 IFrame 通信

javascript - 使用循环从父节点中删除元素

javascript - 检测到循环计数器变量值错误

jquery - Bootstrap Modal + Morris.js 图表

php - 如何使用 jQuery 动态添加表格行和加载动态组合框