我有一个很大的 rar 文件。要解压缩它,我必须使用这个库unrar.js
我正在测试的 blob 大小约为 23MB,为了 readAsArrayBuffer 然后将其提供给 unrar.js,我必须对其进行切片。
由于某种原因,unrar.js 不能很好地处理切片 blob——如果切片 blob 范围不是以 0 开头或以 blob.size 结尾,它会抛出未知的存档类型错误。 -奇怪吗?-
我能想到的唯一解决方法是将 blob 作为切片读取,然后在 onloadend 函数中再次将其收集回来。 -这可能吗?-
将数组缓冲区收集到一个数组中,然后将其提供给 unrar.js 以解压缩文件,就像从一个 blob 中读取文件一样。
如果这听起来对你来说太烦人了,我会很感激任何其他方式在 javascript/phonegap 环境中读取 rar 文件。
我不确定我是否完全理解为什么斑点被分段,但如果是的话,你可能会这样做:
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;
};
虽然上述方法有效,但请持保留态度,因为我对你所做的事情的了解有限,我不知道这是最好的解决方案
我更新了达斯汀的代码 - 现在它的工作速度更快了
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;
}