1

几个小时以来,我一直在纠结一个问题,这个问题在这里被问了几次:我有来自闪存录音机的二进制数据,我将其转换为 dataURL,然后想转换为 blob 以进行上传. SO给了我几个答案,基本上都是一样的:

我根据上面写了下面的代码

var data = window.atob(dataURL.split(',')[1]);
var length = data.length;
var uInt8Array = new Uint8Array(length);
for (var i = 0; i < length; ++i) {
    uInt8Array[i] = data.charCodeAt(i);
}
var myfile = new Blob([uInt8Array], {'type': 'audio/x-wav'});

这在 firefox nightly (20) 和 chrome 25 中完美运行,但 chromium 20 一直告诉我 myfile 的大小是 19 字节(当它应该是几个 kb 时),随后的上传始终失败。这是铬中的一个错误,还是我错过了一个说它还不支持的文档?有什么替代的想法吗?

4

2 回答 2

1

Blob()当使用某些参数调用时,铬的构造函数中似乎存在错误。我缩小了jsfiddle 上的问题(在 chromium 中运行以查看问题,其他浏览器似乎可以正确处理它,两个 blob 大小都应该是 32)

这是我为解决它而放在一起的代码:

var data = window.atob(dataURL.split(',')[1]);
var length = data.length;
var buffer = new ArrayBuffer(length);   // added this line
var uInt8Array = new Uint8Array(buffer);
for (var i = 0; i < length; ++i) {
    uInt8Array[i] = data.charCodeAt(i);
}
// two options here:
// buggy: produces a 19byte long file in chromium
var myfile = new Blob([uInt8Array], {'type': 'audio/x-wav'});
// works in chromium (and firefox), but produces a deprecation warning in chrome
var myfile = new Blob([buffer], {'type': 'audio/x-wav'});

我最终运行了第一个替代方案,然后if (myfile.size == 19) {在需要时获得第二个替代方案

于 2012-12-13T13:29:06.597 回答
1

使用我的代码将 dataURI 转换为 blob。

function dataURLtoBlob(dataURL) {
    var arr = dataURL.split(','), mime = arr[0].match(/:(.*?);/)[1],
        bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    while(n--){
        u8arr[n] = bstr.charCodeAt(n);
    }
    return new Blob([u8arr], {type:mime});
}
于 2015-05-23T01:46:17.607 回答