首页 > 代码库 > ajax中获取和发送二进制数据的方法

ajax中获取和发送二进制数据的方法

来源:三联教程 | 时间:2013-06-08 17:51:48

 用ajax从服务器端获取二进制时, 需要用overrideMimtType设置request头,让浏览器不要修改读取的的数据,方法如下:

var xhr = new XMLHttpRequest();

xhr.onreadystatechange = function(){

if (xhr.readyState=== 4 && xhr.status === 200){

var imgdata = http://www.mamicode.com/xhr.response;

}

}

xhr.open("GET",url,true);

xhr.overrideMimeType("text/plain; charset=x-user-defined");

xhr.send(null);

另外要用xhr.response来获得二进制数据,而不是responseText。

如果需要通过ajax的POST发送二进制数据,在发送前需要将二进制数据的高位变为0,通常在XMLHttpRequest中增加一个方法来实现:

XMLHttpRequest.prototype.sendAsBinary = function(datastr) {

function byteValue(x) {

return x.charCodeAt(0) & 0xff;

}

var ords = Array.prototype.map.call(datastr, byteValue);

var ui8a = new Uint8Array(ords);

this.send(ui8a.buffer);

}

var bindata = http://www.mamicode.com/二进制数据;

xhr.open("POST", url);

xhr.sendAsBinary(bindata);

原文链接:http://www.webjzt.com/zhishi/jianzhan/1251.html