如何将两个数组缓冲区合并为一个?

问题描述 投票:0回答:2

我有一个很大的 rar 文件。要解压缩它,我必须使用这个库unrar.js

我正在测试的 blob 大小约为 23MB,为了 readAsArrayBuffer 然后将其提供给 unrar.js,我必须对其进行切片。

由于某种原因,unrar.js 不能很好地处理切片 blob——如果切片 blob 范围不是以 0 开头或以 blob.size 结尾,它会抛出未知的存档类型错误。 -奇怪吗?-

我能想到的唯一解决方法是将 blob 作为切片读取,然后在 onloadend 函数中再次将其收集回来。 -这可能吗?-

将数组缓冲区收集到一个数组中,然后将其提供给 unrar.js 以解压缩文件,就像从一个 blob 中读取文件一样。

如果这听起来对你来说太烦人了,我会很感激任何其他方式在 javascript/phonegap 环境中读取 rar 文件。

javascript cordova blob fileapi
2个回答
5
投票

我不确定我是否完全理解为什么斑点被分段,但如果是的话,你可能会这样做:

var blobs = [new Blob(['Hello ']),new Blob(['World'])];
var buffers = [];
var buffersFilled = 0;

for(var i=0; i < blobs.length; i++) {
  buffers.push(new Uint8Array()); 
}


for(var i=0; i<blobs.length; i++) {
    var fileReader = new FileReader();
  
    fileReader.onload = (function(i,fileReader) {
      return function(){
        buffers[i] = fileReader.result;
        isBuffersDone();
      }
    })(i,fileReader);
    fileReader.readAsArrayBuffer(blobs[i]);
}

function isBuffersDone() {
  buffersFilled++;
  if(buffersFilled >= blobs.length) {
    var result = spliceBuffers();  
    
    //*****************
    // result is the spliced together buffers that could be given to unrar.js
    console.log(result);
  }
}

function spliceBuffers() {
  var tmpResult = new Uint8Array();
  
  for(var i=0; i < buffers.length; i++) {
    tmpResult = appendBuffer(tmpResult, buffers[i]);
  }
  
  return tmpResult;
}




function appendBuffer(buffer1, buffer2) {
  var tmp = new Uint8Array(buffer1.byteLength + buffer2.byteLength);
  tmp.set(new Uint8Array(buffer1), 0);
  tmp.set(new Uint8Array(buffer2), buffer1.byteLength);
  return tmp;
};

虽然上述方法有效,但请持保留态度,因为我对你所做的事情的了解有限,我不知道这是最好的解决方案


0
投票

我更新了达斯汀的代码 - 现在它的工作速度更快了

function spliceBuffers(buffers) {

  const len = buffers.map((buffer) => buffer.byteLength).reduce((prevLength, curr) => {return prevLength + curr}, 0);
  
  const tmp = new Uint8Array(len);

  let bufferOffset = 0;
  
  for(var i=0; i < buffers.length; i++) {
    tmp.set(new Uint8Array(buffers[i]), bufferOffset);
    bufferOffset += buffers[i].byteLength;
  }
  
  return tmp;
}
© www.soinside.com 2019 - 2024. All rights reserved.