I am converting a base64 String to byte array using atob() function.
我正在使用atob()函数将base64字符串转换为字节数组。
I get the base64String from below code:
我从下面代码得到base64String:
var dataURL = $("#graph-panel .canvasjs-chart-canvas").get(0).toDataURL();
Contents of dataURL is as follows:
dataURL的内容如下:
…
The above base64 String is not a complete string I think. Whatever the string that got printed in the console I have pasted it above.
上面的base64字符串不是我想的完整字符串。无论在控制台打印的字符串是什么,我都将它粘贴在上面。
I am passing this base64 String to the following function:
我将这个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(''));
}
}
While executing the above code I am getting the following errror:
在执行上述代码时,我得到了以下错误:
InvalidCharacterError: String contains an invalid character
invalidcharacter错误:字符串包含无效字符。
[EDIT] Following is the complete Base64 String:
以下是完整的Base64字符串:

2 个解决方案
#1
1
Looks like you're trying to convert a DataURL using the atob()
function, but you have missed a step.
看起来,您试图使用atob()函数来转换一个DataURL,但是您已经错过了一个步骤。
The DataURL contains information about the media type and the encoding like so:
DataURL包含关于媒体类型和编码的信息:
data:[<mediatype>][;base64],<data>
数据:[< mediatype >][;base64], <数据>
You can try retrieving only the data by using String Split on base64,
您可以尝试使用base64上的String Split来检索数据,
Try this:
试试这个:
data = str.split('base64,')[1];
data = str.split(“base64,”)[1];
Reference: https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs
参考:https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs
#2
0
I have achieved the conversion with following code:
我已经完成了以下代码的转换:
var dataURL = $("#graph-panel .canvasjs-chart-canvas").get(0).toDataURL();
var byteArr = b64toArray(dataURL);
function b64toArray(b64Data){
var byteCharacters = atob(b64Data);
var byteNumbers = new Array(byteCharacters.length);
for (var i = 0; i < byteCharacters.length; i++) {
byteNumbers[i] = byteCharacters.charCodeAt(i);
}
var byteArray = new Uint8Array(byteNumbers);
return byteArray;}
#1
1
Looks like you're trying to convert a DataURL using the atob()
function, but you have missed a step.
看起来,您试图使用atob()函数来转换一个DataURL,但是您已经错过了一个步骤。
The DataURL contains information about the media type and the encoding like so:
DataURL包含关于媒体类型和编码的信息:
data:[<mediatype>][;base64],<data>
数据:[< mediatype >][;base64], <数据>
You can try retrieving only the data by using String Split on base64,
您可以尝试使用base64上的String Split来检索数据,
Try this:
试试这个:
data = str.split('base64,')[1];
data = str.split(“base64,”)[1];
Reference: https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs
参考:https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs
#2
0
I have achieved the conversion with following code:
我已经完成了以下代码的转换:
var dataURL = $("#graph-panel .canvasjs-chart-canvas").get(0).toDataURL();
var byteArr = b64toArray(dataURL);
function b64toArray(b64Data){
var byteCharacters = atob(b64Data);
var byteNumbers = new Array(byteCharacters.length);
for (var i = 0; i < byteCharacters.length; i++) {
byteNumbers[i] = byteCharacters.charCodeAt(i);
}
var byteArray = new Uint8Array(byteNumbers);
return byteArray;}