我正在尝试使用jQuery AJAX下载二进制音频文件。
通常我只会发出这样的命令:
windows.location.href = 'http://marksdomain(dot)com/audioFile.wav' ;
但是,最近我们的服务器等待时间太长,无法响应,并且我收到了令人讨厌的网关超时消息。
有人建议我改用jQuery AJAX,从那时起我就可以更好地控制超时了。
这是到目前为止我玩过的代码:
$.ajax({ url: 'http://marksdomain(dot)com/audioFile.wav', timeout: 999999, dataType: 'binary', processData: false, // this one does not seem to do anything ? success: function (result) { console.log(result.length); }, error: function (result, errStatus, errorMessage) { console.log(errStatus + ' -- ' + errorMessage); } };
当我省略“ dataType”时,二进制文件的传输量大约是服务器上实际文件传输量的三倍。但是,当我使dataType等于“ binary”时,AJAX会引发错误:
"No conversion from text to binary"
从以前的一些帖子中,听起来好像jQuery AJAX无法以这种方式处理二进制文件。
我确实发现了Delivery.js,它实际上可以很好地满足我的尝试,但是我宁愿不使用节点解决方案。
有什么建议?
只需直接使用XHR。这个例子取自MDN:
var oReq = new XMLHttpRequest(); oReq.open("GET", "/myfile.png", true); oReq.responseType = "arraybuffer"; oReq.onload = function(oEvent) { var arrayBuffer = oReq.response; // if you want to access the bytes: var byteArray = new Uint8Array(arrayBuffer); // ... // If you want to use the image in your DOM: var blob = new Blob([arrayBuffer], {type: "image/png"}); var url = URL.createObjectURL(blob); someImageElement.src = url; // whatever... }; oReq.send();