当前位置:首页 » 《休闲阅读》 » 正文

前端解压rar文件-node-unrar-js

14 人参与  2024年10月28日 14:40  分类 : 《休闲阅读》  评论

点击全文阅读


问题 : 前端需要解压 rar 压缩包并生成 tree 的数据格式

解决办法 : 使用 node-unrar-js 插件,具体步骤如下

安装包 npm i node-unrar-js@2.0.0 引入 import { createExtractorFromData, UnrarError } from 'node-unrar-js';解压 rar 代码演示:
methods: {getRARMetadata(file) {      return new Promise((resolve, reject) => {        const reader = new FileReader()        var fileList = [];        reader.onload = async () => {          const data = reader.result;         const wasmBinary = await (            await fetch(`../unrar.wasm`, { credentials: 'same-origin' })          ).arrayBuffer();          const extractor = await createExtractorFromData({ wasmBinary, data });          const { arcHeader, fileHeaders } = extractor.getFileList();          for (const fileHeader of fileHeaders) {            fileList.push(fileHeader)          }          resolve(fileList)        };        reader.onerror = error => {          reject(error);        };        reader.readAsArrayBuffer(file);      });    },}

注: getRARMetadata(file) 参数 file 为上传文件之后获取的 file.raw; unrar.wasm 为一个二进制文件,下载地址
运行结果:

在这里插入图片描述

将结果处理成 tree 型结构,代码演示:
    buildRarTree(treeData) {      const tree = []      let filterTreeData = treeData.reverse()      filterTreeData.reverse().forEach((path, i) => {        const segments = path.name.split('/')        let currentNode = tree;        segments.forEach((segment, index) => {          const isLastSegment = index === segments.length - 1          const isDir = path.flags.directory          if (segment !== '') {            // Filter out nodes with empty labels            let existingNode = currentNode.find(node => node.label === segment)            let size = 0            if (!existingNode) {              const filePath = path.name.slice(0,path.name.lastIndexOf('/'))              const newNode = {                uploadFilePath:  `${i}${index}` == '00' ? segment : isLastSegment ? path.name : filePath,                label: segment,                size: isLastSegment ? path.unpSize : 0,                id: i + '' + index,                data: path.time,                dir: isLastSegment ? isDir : true,                type: 2,                forUUIDPath: this.offlineImportParams.url,                md5: h_md5(`${path.unpSize}${path.name}${path.crc}${path.time}`),              }              if (isLastSegment) {                newNode.label = segment              } else {                newNode.children = []              }              currentNode.push(newNode)              existingNode = newNode            }            currentNode = existingNode.children          }        })      })      return tree    },

注: treeData为getRARMetadata函数处理之后的结果
运行结果:
在这里插入图片描述


点击全文阅读


本文链接:http://m.zhangshiyu.com/post/179021.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 进错房,嫁给八零最牛特种兵已完结(林晚夏江肆年)抖音热文_《进错房,嫁给八零最牛特种兵已完结》最新章节免费在线阅读 -
  • 重生后选魔族,天族哭着求我当王全章节(月沁雪任意)全文免费阅读无弹窗大结局_(重生后选魔族,天族哭着求我当王全章节)重生后选魔族,天族哭着求我当王全章节免费阅读全文最新章节列表_笔趣阁(重生后选魔族,天族哭着求我当王全章节) -
  • 捡回摄政王后,她在皇室作威作福完结版小说(景飞鸢赵灵杰)全文免费阅读无弹窗大结局_(捡回摄政王后,她在皇室作威作福完结版免费阅读全文大结局)最新章节列表_笔趣阁(捡回摄政王后,她在皇室作威作福完结版) -
  • 千金难泣(立轩苏子骞翠竹吴进)全本免费在线阅读_千金难泣最新章节在线阅读(立轩苏子骞翠竹吴进)
  • 《沈云阶傅宴辞》(沈云阶傅宴辞》已完结完整版全集大结局小说)全文阅读笔趣阁
  • 《沈凌峰沈国华》已完结小说全文阅读笔趣阁《沈凌峰沈国华》
  • 《傅嫤韩恬魏郯程茂》已完结(傅嫤韩恬魏郯程茂)热门小说全目录完整版)全文阅读笔趣阁
  • 八零俏军医错嫁糙汉军官:番外+全文+后续(贺昭朗孟翩然)完本小说免费_全本免费小说八零俏军医错嫁糙汉军官:番外+全文+后续最新小说全文阅读(贺昭朗孟翩然)
  • 失去千千万万遍在线阅读(阮相宜陆凛言)全文免费阅读无弹窗大结局_(失去千千万万遍在线阅读)失去千千万万遍在线阅读免费阅读全文最新章节列表_笔趣阁(失去千千万万遍在线阅读) -
  • 脱离世界后,妻子疯了火爆小说小说(沈夕颜林程言)全文免费阅读无弹窗大结局_(脱离世界后,妻子疯了火爆小说免费阅读全文大结局)最新章节列表_笔趣阁(脱离世界后,妻子疯了火爆小说) -
  • 跨年发生踩踏,男友为救白月光丢下我(温林初宝宝)免费阅读 -
  • 都重生了,还不离婚等啥呢宋招弟霍文铮小说在线章节免费阅读

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1