从网络浏览器获取Django下载附件

时间:2019-05-17 13:03:56

标签: javascript django browser attachment

我要发送图像作为附件。

我的代码:

resp = FileResponse(open(fullImgPath, "rb"))
resp['Content-Disposition'] = 'attachment; filename="{}"'.format(os.path.basename(fullImgPath))
resp["Content-Type"]="image/%s"%('png' if fullImgPath.endswith('png') else 'jpeg')
return resp

如果我通过requests下载文件,它确实可以工作。但是当我通过浏览器(chrome和firefox)下载文件时,文件已损坏。

我如何通过浏览器(javascript):

$.get(requestUrl)
        .success(function(data, textStatus, request){
                SaveBlob(data, "1,jpeg", "image/jpeg")
            }
        })

function SaveBlob(blob, fileName, contentType) {
    var a = document.createElement('a');
    a.href = window.URL.createObjectURL(new Blob([blob], { "type" : contentType }));
    a.download = fileName;
    a.dispatchEvent(new MouseEvent('click'));
}

以前有效!今天我发现我得到的文件已损坏。但是,存储在服务器上的文件是正常图像。

怎么了?

1 个答案:

答案 0 :(得分:0)

jQuery不会将文件内容下载为二进制文件,因此图像已损坏。看起来jquery不支持以二进制形式下载,但是您可以使用本机xhr:

function SaveBlob(blob, fileName, contentType) {
    var a = document.createElement('a');
    a.href = window.URL.createObjectURL(new Blob([blob], {"type": contentType}));
    a.download = fileName;
    a.dispatchEvent(new MouseEvent('click'));
}

var oReq = new XMLHttpRequest();
oReq.open("GET", requestUrl, true);
oReq.responseType = "arraybuffer";
oReq.onload = function (oEvent) {
    SaveBlob(oReq.response, '1.jpg', 'image/jpg')
};
oReq.send();

想知道它以前是如何工作的。