前端js解析websocket推送的gzip压缩json的Blob数据

主要依赖插件pako https://www.npmjs.com/package/pako

1、安装

bash 复制代码
npm install pako

2、使用, pako.inflate(reader.result, {to: "string"}) 解压后的string 对象,需要JSON.parse转成json

javascript 复制代码
  this.ws.onmessage = (evt) => {
        console.log("websocket推送=====",evt.data instanceof Blob)
        var messageData = evt.data;
        try {
// S 解压主要代码
          if(evt.data instanceof Blob){
              let reader = new FileReader();
              reader.readAsArrayBuffer(evt.data, "utf-8");
              reader.onload =() =>{
                // 对数据进行解压
                messageData = pako.inflate(reader.result, {to: "string"})
               console.log("解析压缩",messageData)
              }
          }
// E 解压主要代码

        } catch (error) {
          console.log("推送报错-blob",error)
        }



....

3、使用发现解析压缩会存在异步,导致解压未完成后续代码执行会报错,优化

javascript 复制代码
// 解析websocket推送的gzip blob数据to json
const pakoUngzipToJson = (messageData) => {
  return new Promise((resolve, reject) => {
    try {
      let reader = new FileReader();
      reader.readAsArrayBuffer(messageData, "utf-8");
      reader.onload = () => {
        // 对数据进行解压
        let ungzipData = pako.inflate(reader.result, { to: "string" });
        resolve(ungzipData);
      };
    } catch (error) {
      console.log("推送解析报错-blob", error);
      reject(error);
    }
  });
};


//使用

 receive: async (message) => {
    var messageData = message.data;
    if(messageData instanceof Blob){
      console.time("解析数据gzip-web")
      messageData = await pakoUngzipToJson(messageData)
      console.timeEnd("解析数据gzip-web")
    }

    var params = JSON.parse(messageData);

......
相关推荐
ID_180079054736 小时前
淘宝商品详情API的调用频率限制是多少?
大数据·数据库·json
wefly20177 小时前
jsontop.cn:一站式 JSON 全能工具集,开发全流程效率神器
前端·javascript·python·django·json·json在线转换
电商API&Tina1 天前
比价 / 选品专用:京东 + 淘宝 核心接口实战(可直接复制运行)
大数据·数据库·人工智能·python·json·音视频
进击的雷神1 天前
攻克JSON嵌套HTML的双重解析难题:基于多层数据提取的精准爬虫设计
爬虫·html·json·spiderflow
进击的雷神1 天前
攻克JSON接口分页与对象数组处理:基于AJAX数据源的精准博客爬虫设计
爬虫·ajax·json·spiderflow
不会写DN1 天前
Go 生态最快 JSON 库 - jsoniter
开发语言·golang·json
KevinCyao1 天前
批量发短信接口的数据格式设计:CSV、JSON还是XML?
xml·前端·前端框架·json
电商API&Tina1 天前
主流跨境平台多站点 API 接入流程:淘宝天猫京东API接口
java·大数据·网络·数据库·人工智能·sql·json
西门吹牛1 天前
RV1126B移植mosquitto并且写C语言调用
c语言·开发语言·json
电商API&Tina2 天前
电商数据采集API接口||合规优先、稳定高效、数据精准
java·javascript·数据库·python·json