javascript - 未捕获的无效字符错误 : failed to convert to blob from base64 image

标签 javascript node.js base64 blob

我尝试将 base64 转换为 blob,但收到错误 Uncaught InvalidCharacterError: 无法在“Window”上执行“atob”:要解码的字符串未正确编码。

我在这里测试了我的base64图像数据http://codebeautify.org/base64-to-image-converter它工作得很好,我可以看到图像渲染得很好

 function b64toBlob(b64Data, contentType, sliceSize) {
            contentType = contentType || '';
            sliceSize = sliceSize || 512;

            var byteCharacters = atob(b64Data);
            var byteArrays = [];

            for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
                var slice = byteCharacters.slice(offset, offset + sliceSize);

                var byteNumbers = new Array(slice.length);
                for (var i = 0; i < slice.length; i++) {
                    byteNumbers[i] = slice.charCodeAt(i);
                }

                var byteArray = new Uint8Array(byteNumbers);

                byteArrays.push(byteArray);
            }

            var blob = new Blob(byteArrays, {type: contentType});
            return blob;
        }

      var blob = b64toBlob(base64Data, 'image/jpeg'); 
      console.log(blob)

https://jsfiddle.net/wfh5fjn9/

最佳答案

发生的情况是您将 data:image/jpeg;base64, 保留在 base64Data 字符串中。您需要将其删除,并仅保留实际上经过 base64 编码的字符串才能使其正常工作。

换句话说,

var base64Data = 'data:image/jpeg;base64,/9j/4AAQSkZJRgABAQ' // truncated

变成了

var base64Data = '/9j/4AAQSkZJRgABAQ' // truncated

https://jsfiddle.net/wfh5fjn9/1/

关于javascript - 未捕获的无效字符错误 : failed to convert to blob from base64 image,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38579262/

相关文章:

echo javascript 函数的 php 语法

javascript - 三个js改变一个饼图切片的位置

javascript - Sinon 的意外断言错误

node.js - React Native Node安装错误

python - 抓取 img src 输出到 base64

c++ - 为什么 65537 不使用 CryptoPP 将 base64URL 编码为 "AQAB"?

java - 在 Java 中将多页 TIFF 转换为 Base64 字符串

javascript - react : Trying to set an API JSON response to state object and pass it to component for mapping and rendering

javascript - 为什么我的 Controller 没有被导出?

macos - Nodejs www mac os x 服务器