使用javascript将ByteArray转换为blob

时间:2013-07-10 13:27:35

标签: javascript bytearray blob

我正在使用flash捕获音频,将其编码为mp3,然后将其作为ByteArray发送到javascript。 现在我希望javascript将它保存为我的电脑上的MP3(不是闪存将它保存到我的电脑)。我正在使用Blob然后使用getDataURL,但保存后该文件无法播放。我曾经用同样的方法来保存WAV文件,它工作得很好。 这是JS代码:

var getDataFromSWF = function (bytes) {
            var myBlob = new Blob([bytes], { type: "audio/mpeg3" });

            var url = (window.URL || window.webkitURL).createObjectURL(myBlob);
            var link = window.document.createElement('a');
            link.href = url;

//            $("label").text(url);
            link.download = 'output.mp3';
            var click = document.createEvent("Event");
            click.initEvent("click", true, true);
            link.dispatchEvent(click);

//            console.log(bytes);
        }

我非常确定byteArray很好,因为如果我让SWF保存文件它也可以正常工作。但我想知道JS代码有什么问题。 (注意:我是BLOB的新手)

1 个答案:

答案 0 :(得分:0)

试试这个来获取Blob

function base64toBlob(base64Data, contentType) {
var sliceSize = 1024;
var byteCharacters = atob(base64Data);
var bytesLength = byteCharacters.length;
var slicesCount = Math.ceil(bytesLength / sliceSize);
var byteArrays = new Array(slicesCount);
for (var sliceIndex = 0; sliceIndex < slicesCount; ++sliceIndex) {
    var begin = sliceIndex * sliceSize;
    var end = Math.min(begin + sliceSize, bytesLength);
    var bytes = new Array(end - begin);
    for (var offset = begin, i = 0 ; offset < end; ++i, ++offset) {
        bytes[i] = byteCharacters[offset].charCodeAt(0);
    }
    byteArrays[sliceIndex] = new Uint8Array(bytes);
}
return new Blob(byteArrays, { type: contentType });

}