小编use*_*130的帖子

AJAX响应提供了损坏的压缩(.tgz)文件

我们正在实现一个客户端Web应用程序,它通过XMLHttpRequests(和AJAX引擎)专门与服务器通信.

XHR响应通常是纯文本,上面有一些XML,但在这种情况下,服务器正在发送.tgz文件类型的压缩数据.我们确定服务器发送的数据是正确的,因为如果我们使用诸如curl的HTTP命令行客户端,则作为响应发送的文件是有效的并且包含预期的数据.

但是,当在可下载文件中进行AJAX调用并"响应"响应时,我们获得的文件的大小(更高)与正确的文件不同,并且解析器无法识别它.它给出以下错误:

gzip: stdin: not in gzip format
/bin/gtar: Child returned status 1
/bin/gtar: Error is not recoverable: exiting now
Run Code Online (Sandbox Code Playgroud)

我正在使用的代码如下:

*$.AJAX*.done(function(data){
    window.URL = window.webkitURL || window.URL;
    var contentType = 'application/x-compressed-tar';
    var file = new Blob([data], {type: contentType});
    var a = document.createElement('a'),
    ev = document.createEvent("MouseEvents");
    a.download = "browser_download2.tgz";
    a.href = window.URL.createObjectURL(file);
    ev.initMouseEvent("click", true, false, self, 0, 0, 0, 0, 0,
            false, false, false, false, 0, null);
    a.dispatchEvent(ev);
});
Run Code Online (Sandbox Code Playgroud)

我避免了用于进行AJAX调用的参数,但我们假设这不是问题,因为我正确地收到了答案.我使用了这个contentType,因为它与curl获得的相同,但我尝试了不同的内容.代码可能看起来有点怪异,所以我会为你解毒它:我基本上是创建一个链接,我附加了它的下载链接和文件的名称(这是一个肮脏的方式来命名文件).最后,我实际上是点击链接.

我将正确的tgz文件和通过浏览器获得的文件与十六进制查看器进行了比较,我观察到了损坏的文件(EF,BF和BD,整个文件)中重复的模式,这些模式在正确的模式中不存在.

因此,我想一些可能的原因:

(a)浏览器正在添加额外的字符,或者响应头仍然在下载的文件中.

(b)文件已被部分解压缩,因为当我检查请求标题时,我可以说"Accept-Encoding:gzip,deflate"; 虽然我不知道浏览器(在我的情况下是Firefox)是否会自动解压缩数据.

(c)我用来填充数据的代码不正确; 虽然它在另一个场合用普通/文本文件很好地完成了目标.

编辑

我还为您提供了十六进制检查的链接:

(a)文件损坏: …

javascript compression ajax download gunzip

7
推荐指数
1
解决办法
2583
查看次数

标签 统计

ajax ×1

compression ×1

download ×1

gunzip ×1

javascript ×1