1.調用接口,返回二進制流數據ide
var xhr = new XMLHttpRequest(); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) {// var responseText = xhr.responseText; //返回二進制數據流 console.log(responseText); } }; xhr.open("GET", "/getData", true);
//須要設置responseType
xhr.responseType = "arraybuffer";
xhr.send(null)
2. 把二進制數據轉爲base64url
function arrayBufferToBase64(buffer) { var binary = ''; var bytes = new Uint8Array(buffer); var len = bytes.byteLength; for (var i = 0; i < len; i++) { binary += String.fromCharCode(bytes[i]); } return window.btoa(binary); }
3.顯示圖片spa
var response = xhr.response; var url= arrayBufferToBase64(response); document.getElementById('img').src='data:image/jpeg;base64,'+url;
完整代碼code
var xhr = new XMLHttpRequest(); xhr.open("GET", "/getdata", true); xhr.responseType = "arraybuffer"; xhr.send(null); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { //二進制數據流 var response = xhr.response; var url= arrayBufferToBase64(response); document.getElementById('img').src='data:image/jpeg;base64,'+url; } }; function arrayBufferToBase64(buffer) { var binary = ''; var bytes = new Uint8Array(buffer); var len = bytes.byteLength; for (var i = 0; i < len; i++) { binary += String.fromCharCode(bytes[i]); } return window.btoa(binary); }