如何从XHR请求响应字符串中转换/解码Base64

3

我一直遇到将XHR请求响应正确转换的问题。我已经在Stackoverflow和其他平台上阅读了几个解决方案,但无法成功将字符串转换为dataURL。

我尝试通过MDN和这个Stackoverflow帖子中提到的atob()btoa()方法将字符串转换,以及使用许多不同的方法寻找解决方案,但没有一个方法能够帮助我。

如何正确将下面的响应转换为dataURL,以便能够将其设置为image src的URL?

XHR请求响应:

    "�PNG


IHDR��  m"H3PLTE���������������������������������������������������?�U�iIDATx�흋�� Eۈ�Z����R�[���BB�]�_�Y�� x��a�a�a�a�a�a�a�a��-��nFI]]�}_x�}�����$ʆ�h�s�_4M_w�WI��*��.o���"��~۔�C^uڟ�P5W�'�[��(��}�=)���U�����Z�J#U��G�'�8G�߻ۓH�>��E���G�>݁K�ތ4l��C��
v�xu���?�*R��^������ł�B[�Y׸kkY����=�

l|H�s7Yp"���+6zV�cvSj+�
�}�c�c݄Pކ
~�W�N֨(�3����0[QƄ�Q�)o�_R,�]J����G�b��?��M  9�  w*h��!=�%"�4������˔*a��

���6��w'��>��el3�e�l����c�ݍ(U.p�Q2�э����#��BɺB�h�4Sh��I�
�s��B���P735���(L�KU_�����s��v�]~�������6�+
/��iD���    �����uԏf�ﳽ�}nA�1_7��t�
+m�2W���P:�8�N�.Ԉ}�KQ�`�G0�P�Y�}�=A|�$� ��Xǭ�؅)w���>����m�J�R�֖��~}�n�@�G��7�ͽ���d������58C��i�6|�&�ۄ?pIl:P�l   *FE�
q��wj��v��6�.�BQ�߁�����GBm�{�(�
�!f�k�Df*?}�+�N��"u��V,N��.eҚj��r�t��А�r��>)��*a��J����4�U���L��Z�/�ҵ���e=�;Qp����=x�[5=N��:8O}��k�?�Rr"�ma��tڱQ�I���R���=ܣU�MI�3Y�6\�~�v�.yJ�)��q�&���/�_�R�A-����{Ҡ�$��RNx%�}'�D�Tm�d9��}�n��~�kz��Ӝ���K� b��] L|�iqo3�O��p��l��  'd�$�D�!:e��F=����'�"7g�F=b��7+Qܤ֩n�_"��c�����w$~`�V�"��I�{�&R̰G�O�|��%�    ��/�L���>�  �wb�S����- �3O����*J��7�͈�
�m�JL�Fdҗ��0��>���0��<����0�I!�33,y
d>3Ò�<y��)�'�pxS�E����;�����)�2�p��Dt��P�*�����Y�.�܈�
��D�5�Y�Ld����l��cb�lQ�|4�DED�͒�n
^3��&F!|��D��?�'��q
G�jN�h�\�   2ODVu�d���'���LLs_�ۏ�>CV�   �gQ�{���e�  
���2��*�Q�>|y��fg�M9a��E�IEND�B`�"

更新:

我已经成功通过这篇文章https://dev59.com/XGsz5IYBdhLWcg3wQFe2#8022521来渲染图片。


谢谢您提供更新的链接!那是唯一对我有效的东西。 - Rodrigo
1个回答

1

您的XHR数据是一个png文件,如预期所示。为了向您展示如何嵌入它,请容许我生成一个“更好”的PNG——一个10x10黄色正方形,并将其以Base64编码方式放在代码片段的第一行中的b64data变量中。第二行将yourData设置为您从XHR获取的内容。

var b64data = "iVBORw0KGgoAAAANSUhEUgAAAAoAAAAKCAYAAACNMs+9AAAAFklEQVR42mP8/5/hDAMRgHFUIX0VAgBfZRvvtreybgAAAABJRU5ErkJggg==";

// Assuming your data is a raw PNG
var yourData = atob(b64data);

// We convert...
var btoa_data = btoa(yourData);

var elem = document.createElement("img");
elem.src = "data:image/png;base64,"+btoa_data;
document.getElementById("app").append(elem);
console.log(atob(b64data));
<div id="app"></div>

正如您所看到的,btoa() 可以用于将数据进行 base64 编码;在此之后,您需要做的唯一一件事就是在 img 标签的 src 部分指示:

  • 它是 PNG(如果不是,或者您不确定它是否是,您需要检查回复的前几个字节)
  • 它是 base64 编码的

感谢您的回答。我已经将响应设置为变量; var atob_data = atob(event.target.response);,这与Post上的响应相同,但是它返回以下错误; Uncaught DOMException: Failed to execute 'atob' on 'Window': The string to be decoded contains characters outside of the Latin1 range. - Nuri Engin
@NuriEngin 将您的脚本保存为UTF8,然后再尝试。atob/btoa 对调用它们的脚本的字符编码非常敏感,看起来这就是现在困扰你的问题所在。 - Sébastien Renauld
1
如果我理解正确的话,我已经使用之前做过的这个嵌套方法进行了转换:var btoa_data = window.btoa(unescape(encodeURIComponent(event.target.response)));。我成功地进行了转换,但是没有成功将图像呈现到元素中。这是HTML上的结果@ https://postimg.cc/cgqQBk4f,这是DevTools上元素的src @ https://postimg.cc/R31cGQ38。 - Nuri Engin

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接