javascript - 使用 atob() 将 base64 解码为字节时出现 InvalidCharacterError : String contains an invalid character,

标签 javascript base64

我正在使用 atob() 函数将 base64 字符串转换为字节数组。

我从下面的代码中得到 base64String:

var dataURL = $("#graph-panel .canvasjs-chart-canvas").get(0).toDataURL();

dataURL的内容如下:

…

上面的base64 String我觉得不是一个完整的字符串。无论控制台中打印的是什么字符串,我都已将其粘贴到上面。

我将这个 base64 字符串传递给以下函数:

var bytes = b64DecodeUnicode(dataUrl);

function b64DecodeUnicode(str) {
console.log(str);
// Going backwards: from bytestream, to percent-encoding, to original string.
return decodeURIComponent(atob(str).split('').map(function(c) {
    return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);
}).join(''));

执行上述代码时出现以下错误:

InvalidCharacterError: String contains an invalid character

[编辑] 完整的Base64字符串如下:



最佳答案

看起来您正在尝试使用 atob() 转换 DataURL功能,但你错过了一步。

DataURL 包含有关媒体类型和编码的信息,如下所示:

data:[<mediatype>][;base64],<data>

您可以尝试在 base64, 上使用 String Split 仅检索数据

试试这个:

data = str.split('base64,')[1];

引用:https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs

关于javascript - 使用 atob() 将 base64 解码为字节时出现 InvalidCharacterError : String contains an invalid character,,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48295641/

相关文章:

javascript - Webpack 热模块替换,react 18 ReactDOMClient.createRoot() 在之前已经传给 createRoot() 的容器上

audio - 如何将 MP3 文件转换为 Base64 编码的字符串?

javascript - Canvas HTML5 数据点到数组

javascript - 使用 javascript 根据图像的布局方向向图像添加不同的类名?

javascript - 上传图片到本地存储

Android:提高上传到服务器的图像质量

仅使用 JDK6 进行 Base64 解码

java - 使用 Scala 或 Java 进行 Base 64 编码

javascript - 如何使用 getElementsByName 访问复选框及其值

javascript - 使用 AJAX 时 Passport + Express4 未通过身份验证