【问题标题】:converting ByteArray into blob using javascript使用 javascript 将 ByteArray 转换为 blob
【发布时间】:2013-07-08 10:56:56
【问题描述】:

我正在使用 Flash 捕获音频,将其编码为 mp3,然后将其作为 ByteArray 发送到 javascript。 现在我希望 javascript 将它作为 MP3 保存在我的计算机上(不是 flash 将它保存到我的计算机上)。我正在使用 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 的新手)

【问题讨论】:

    标签: javascript bytearray blob


    【解决方案1】:

    试试这个来获取 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 });
    }
    

    【讨论】:

    • 我正在发送字节数组并接收 base64 作为响应内容 - 除了这个没有任何效果 - 非常感谢!
    猜你喜欢
    • 1970-01-01
    • 2015-04-01
    • 2017-07-17
    • 2010-10-28
    • 2014-04-28
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多