接收二進制流(ArrayBuffer) ,而且顯示二進制流圖片

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);
    }
View Code
相關文章
相關標籤/搜索