微信小程序zip解压(jsZip插件篇)

前言:使用微信官方文档unzip来解压文件,安卓用户没问题可以正常显示解压,但是在真机调试中苹果用户解压出来的目录是空的;

小程序构建package.json文件

在app.js所在目录层级打开终端运行npm init

安装依赖文件jszip,file-saver;

npm i -s jszip
npm i -s file-saver

安装好后再开发工具中找到工具-构建npm

构建成功后开写入你的逻辑;

此处直接调到已经使用wx.downloadFile下载好压缩包保存到本地;

之前的代码查看

使用jszip(读取压缩包里面的内容,使用微信官方api进行保存)

在使用文件中引入

// 头部引入
const JSZip = require("jszip");
​
//方法
async jsZipLoad(filePath) {
    const jszip = new JSZip();
    // 使用微信官方api读取压缩包
    let res = fs.readFileSync(filePath); 
    // 转换成流
    const binData = new Uint8Array(res);
    // jszip方法loadAsync读取压缩包;
    let zip = await jszip.loadAsync(binData);
    // 得到压缩包内的文件
    for (let key in zip.files) {
      let zipEntry = zip.files[key]; //每个文件
      if (zipEntry.dir) { //判断是否是文件夹
        let createPath = `${filePath.slice(0,filePath.lastIndexOf('.'))}/${zipEntry.name.slice(0,zipEntry.name.length-1)}`;
        let res = fs.accessSync(createPath);//是文件夹先判断本地是否已创建,已创建直接省略,没创建则创建
        if(!res){
          fs.mkdirSync(createPath, true);
        }
      } else {
        // 创建文件并写入
        let data = await zipEntry.async("arraybuffer"); //得到每个文件流
        fs.writeFile({
          filePath: `${filePath.slice(0,filePath.lastIndexOf('.'))}/${zipEntry.name}`,
          data,
          encoding: 'utf8',
          complete(e) {}
        });
      }
    }
    let readdirLocal = fs.readdirSync(`${filePath.slice(0,filePath.lastIndexOf('.'))}`); //读取解压后保存到本地的文件
    console.log('可展示为列表',readdirLocal)
  }

注意:程序运行中可能会出现错误:setImmediate is not defined ,出现这个错误的原因是因为setImmediate是node语言的语法,只需要要在node_modules/jszip/jszip.js中delay方法中的setImmediate改成setTimeout,再重新构建一下npm就行

exports.delay = function(callback, args, self) {
    setImmediate(function () { //将setImmediate改成setTimeout
        callback.apply(self || null, args || []);
    });
};

Jcompress 是一款基于哈夫曼编码和最小堆的无损压缩、解压小程序,支持任何格式的文件的压缩与解压缩。Jcompress 的源代码位于 Utility 的 repository 分类下的 Jcompress 目录,后续会在 Utility 下面增加其他一些实用的小程序,比如基于 socket 的文件断点下载小程序等等。Jcompress代码实现1. 最小堆代码实现最小堆排序算法基本上是按照严蔚敏版的算法来实现的,其具体功能这里不再赘述,仅列出代码,读者可以参考课本自行分析之。首先是heap_min_adjust,也就是调整堆,代码如下所示:int heap_min_adjust(HuffmanNode **huffman_node_array, long data_start, long data_end){       /**       ** check error for argument       */       if(huffman_node_array==NULL || data_start<0 || data_end<0 || data_end<data_start){           printf("heap_min_adjust: argument error\n");           exit(0);       }          if(data_end==data_start) return 1;       /**       ** the top of heap-min indicated by index data_start is the only element       ** which need to be adjusted to make a min-heap       */       HuffmanNode * current_data_tobe_adjust=huffman_node_array[data_start];       long current_indexof_data=data_start;          for(long cur=2*data_start;cur<=data_end;cur=2*cur){           if(curdata_8bit_count)>((huffman_node_array[cur 1])->data_8bit_count)){                   cur =1;               }           }           if((current_data_tobe_adjust->data_8bit_count)data_8bit_count))               break;           huffman_node_array[current_indexof_data]=huffman_node_array[cur];           current_indexof_data=cur;       }       huffman_node_array[current_indexof_data]=current_data_tobe_adjust;       /**       ** return 1 means everything is ok       */       return 1;   }接下来是heap_min_construct()的代码,此函数是通过不断的调用上面的调整堆的函数来达到堆排序的目的。int heap_min_construct(HuffmanNode **huffman_node_array, long array_size){       /** valid data start from index 1 not 0 */          /**       ** check error for argument       */        if(huffman_node_array==NULL || array_size256){           printf("heap_min_construct: argument error\n");           exit(0);        }           for(long HeapRoot=array_size/2; HeapRoot>=1;HeapRoot--){           heap_min_adjust(huffman_node_array,HeapRoot,array_size);        }        return 1;   }最后是heap_min_get2min()函数。int heap_min_get2min(HuffmanNode **huffman_node_array, HuffmanNode **min_first, HuffmanNode **min_second, long *heap_size){          /**       ** check argument       **/        if(huffman_node_array==NULL){           printf("heap_min_get2min: argument error\n");           exit(0);        }          *min_first=huffman_node_array[1];       huffman_node_array[1]=huffman_node_array[*heap_size];       (*heap_size)-=1;       /** after we get the min data, we should again adjust the heap to make a min-heap */       heap_min_adjust(huffman_node_array,1,*heap_size);          *min_second=huffman_node_array[1];       huffman_node_array[1]=huffman_node_array[*heap_size];       (*heap_size)-=1;          /** the same as above*/       if(*heap_size>0){           heap_min_adjust(huffman_node_array,1,*heap_size);       }          return 1;   } 标签:Jcompress
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值