zoukankan      html  css  js  c++  java
  • js发送和接收二进制字节流数据

    前端使用TypedArray编辑二进制

      ES6提供了, ArrayBuffer和TypedArray, 让前端也可以直接操作编辑二进制数据, 网页中的类型为file的input标签, 也可以通过FileReader转化为二进制, 然后再做编辑等, 本文提供参考;

      ArrayBuffer : 代表内存之中的一段二进制数据, 通过它我们可以直接创建二进制对象,然后使用相关的方法和属性。

      如何使用ArrayBuffer:

      new ArrayBuffer(32), 从内存中申请32个字节;

      把ArrayBuffer转换为可以编辑的TypedArray, 然后修改typedArray的内容, 接着再把二进制的数据转化为blob类型的数据,再把blob对象转化为一个url数据, 接着就可以把blob文件下载下来:

    var ab = new ArrayBuffer(32)
    var iA = new Int8Array(ab)
    iA[0] = 97;//把二进制的数据的首位改为97 ,97为小写字母a的ascll码;
    var blob = new Blob([iA], {type: "application/octet-binary"});//把二进制的码转化为blob类型
    var url = URL.createObjectURL(blob);
    window.open(url)

    网站上类型为file的input如果选择了文件, 那么input的value其实就继承了Blob数据,测试demo:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
    </head>
    <body>
        <input type="file" id="f">
        <script>
            var eF = document.getElementById("f");
            eF.onchange = function() {
                var file = eF.files[0];
                console.log(file instanceof Blob)
            }
        </script>
    </body>
    </html>

    FileReader读区blob文件

    我们也可以使用FileReader读取blob数据,并打印出来:

    var ab = new ArrayBuffer(32)
    var iA = new Int8Array(ab)
    iA[0] = 97
    var blob = new Blob([iA], {type: "application/octet-binary"});
    var fr = new FileReader();
    fr.addEventListener("load", function(ev) {
        console.log(ev.target.result);//会输出字符:a
    });
    fr.readAsText(blob)

    blob转化为typedArray

    如果要把blob文件转化为二进制的数据的话,要先把blob转化为arraybuffer,然后再使用typedArray就可以直接编辑二进制数据了:

    var ab = new ArrayBuffer(32)
    var iA = new Int8Array(ab)
    iA[0] = 97
    var blob = new Blob([iA], {type: "application/octet-binary"});
    var fr = new FileReader();
    fr.addEventListener("load", function(ev) {
        var abb = ev.target.result;
        var iAA = new Int8Array(abb);
        console.log(iAA);
    });
    //把blob文件转化为arraybuffer;
    fr.readAsArrayBuffer(blob)

    arraybuffer -->> typedarray -->> blob -->> blob通过FileReader转化为 arraybuffer或者text文本或者base64字符串;

      arraybuffer和typedarray主要是处理二进制, 如果要把blob往二进制转换, 必须先把blob转换为arraybuffer, 然后再转换为可以编辑的typedArray;

      实际上, 还有一种比较常用的数据类型, base64编码的数据, 常用的比如image的base64的编码, 文本的base64编码等, 也可以把base64的编码转化为对应的ascll码,再转化为typearray ,然后再生成blob对象:

    function dataURLtoBlob(dataurl) {
        var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
        //通过atob把base64转化为ascll码, 然后再把ascll码转化为字节码
        while(n--){
          u8arr[n] = bstr.charCodeAt(n);
        }
      //u8arr就是2进制的数据
      return new Blob([u8arr], {type:mime});
    }


    • 发送二进制数据

    var oReq = new XMLHttpRequest();
    oReq.open("POST", url, true);
    oReq.onload = function (oEvent) {
    // Uploaded.
    };
    var blob = new Blob(['abc123'], {type: 'text/plain'});
    oReq.send(blob);
    View Code

    或者

    var myArray = new ArrayBuffer(512);
    var longInt8View = new Uint8Array(myArray);
    for (var i=0; i< longInt8View.length; i++) {
    longInt8View[i] = i % 255;
    }
    var xhr = new XMLHttpRequest;
    xhr.open("POST", url, false);
    xhr.send(myArray);
    View Code
    • 接收二进制数据

    var oReq = new XMLHttpRequest();
    oReq.open("GET", "/myfile.png", true);
    oReq.responseType = "arraybuffer";
    oReq.onload = function (oEvent) {
    var arrayBuffer = oReq.response; // Note: not oReq.responseText
    if (arrayBuffer) {
    var byteArray = new Uint8Array(arrayBuffer);
    for (var i = 0; i < byteArray.byteLength; i++) {
    }
    }
    };
    oReq.send(null);
    View Code

    如上设置只能是文本类型,如果是Blob类型:

    var oReq = new XMLHttpRequest();
    oReq.open("GET", "/myfile.png", true);
    oReq.responseType = "arraybuffer";
    oReq.onload = function(oEvent) {
    var blob = new Blob([oReq.response], {type: "image/png"});
    // ...
    };
    oReq.send();
    View Code

    或者

    var oReq = new XMLHttpRequest();
    oReq.open("GET", "/myfile.png", true);
    oReq.responseType = "blob";
    oReq.onload = function(oEvent) {
    var blob = oReq.response;
    // ...
    };
    oReq.send();
    View Code

    旧版本的浏览器:

    function load_binary_resource(url) {
    var req = new XMLHttpRequest();
    req.open('GET', url, false);
    //XHR binary charset opt by Marcus Granado 2006 [http://mgran.blogspot.com]
    req.overrideMimeType('text/plain; charset=x-user-defined');
    req.send(null);
    if (req.status != 200) return '';
    return req.responseText;
    }
    View Code

    相关链接:

    ArrayBuffer和TypedArray,以及Blob的使用

    HTML5新特性之文件和二进制数据的操作

    js发送和接收二进制字节流数据

    js操作二进制数据

  • 相关阅读:
    python的垃圾回收机制
    生成器
    装饰器
    模块与包
    MES实施会有哪些情况?为你介绍两种常见的类型
    中国智慧工厂未来发展及趋势几何?这里给你讲个清楚
    未来智能工厂是什么样?这五种产业必不可少
    制造企业非常头疼的插单问题,本文给你这些实用建议,第7点最具价值
    MES选型很困惑?避开这三个禁忌!
    如何适应应用场景?高级排程系统的功能如此强大!
  • 原文地址:https://www.cnblogs.com/7qin/p/14391609.html
Copyright © 2011-2022 走看看