需要将AJAX响应转换为blob

时间:2018-05-05 11:09:23

标签: javascript jquery ajax blob

我编写了一个用于在url中设置请求标头的ajax代码,并将其转换为blob并传递给函数showFile (blob);然后以pdf格式处理和下载blob 代码中获得的blob值为undefined。有人可以帮我解决问题吗?

   var resolved = function (url) {
        var showFile = function (blob) {
            var newBlob = new Blob([blob], {type:"application/pdf"})                   
            const data = window.URL.createObjectURL(newBlob);
            var link = document.createElement('a');
            link.href = data;
            link.download = options.name;
            link.click();
            setTimeout(function () {
                window.URL.revokeObjectURL(data);
            }, 100)
        }
        var jwtToken = localStorage.getItem("jwtToken");
        var headerObj = {"Authorization": "Bearer " + jwtToken}

        var xhr = new XMLHttpRequest();
        $.ajax({
            dataType:'blob',
            type:'GET',
            url:url
        }).done(function(blob){
            showFile(blob); 
        });
    };

1 个答案:

答案 0 :(得分:2)

如果您需要来自jQuery ajax的blob响应,请将responseType的{​​{1}}字段设置为xhrFields。 由于响应将是一个blob,您不必创建一个 此外,您是否忘记将auth标头添加到请求中?

blob