前端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);

......
相关推荐
CSCN新手听安13 小时前
【linux】网络基础(三)TCP服务端网络版本计算器的优化,Json的使用,服务器守护进程化daemon,重谈OSI七层模型
linux·服务器·网络·c++·tcp/ip·json
bloglin9999914 小时前
Qwen3-32B报错Invalid json output:{“type“: “1“}For troubleshooting, visit
llm·json
Trouvaille ~15 小时前
【Linux】应用层协议设计实战(二):Jsoncpp序列化与完整实现
linux·运维·服务器·网络·c++·json·应用层
剩下了什么1 天前
MySQL JSON_SET() 函数
数据库·mysql·json
梦帮科技1 天前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
数据知道1 天前
PostgreSQL实战:详解如何用Python优雅地从PG中存取处理JSON
python·postgresql·json
缘空如是2 天前
基础工具包之JSON 工厂类
java·json·json切换
墨痕诉清风2 天前
CVS文件转Json格式
json·python3·cvs
数研小生2 天前
1688商品列表API:高效触达批发电商海量商品数据的技术方案
大数据·python·算法·信息可视化·json
devmoon3 天前
快速了解兼容 Ethereum 的 JSON-RPC 接口
开发语言·网络·rpc·json·区块链·智能合约·polkadot