簡體   English   中英

使用 javascript 將 ByteArray 轉換為 blob

[英]converting ByteArray into blob using javascript

我正在使用 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 的新手)

試試這個來獲取 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 });
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM