• <tfoot id='7dcTa'></tfoot>
      <bdo id='7dcTa'></bdo><ul id='7dcTa'></ul>
  • <legend id='7dcTa'><style id='7dcTa'><dir id='7dcTa'><q id='7dcTa'></q></dir></style></legend>

    <i id='7dcTa'><tr id='7dcTa'><dt id='7dcTa'><q id='7dcTa'><span id='7dcTa'><b id='7dcTa'><form id='7dcTa'><ins id='7dcTa'></ins><ul id='7dcTa'></ul><sub id='7dcTa'></sub></form><legend id='7dcTa'></legend><bdo id='7dcTa'><pre id='7dcTa'><center id='7dcTa'></center></pre></bdo></b><th id='7dcTa'></th></span></q></dt></tr></i><div id='7dcTa'><tfoot id='7dcTa'></tfoot><dl id='7dcTa'><fieldset id='7dcTa'></fieldset></dl></div>

    <small id='7dcTa'></small><noframes id='7dcTa'>

      1. 在 node.js 中解码 Base64 字符串

        Decode Base64 string in node.js(在 node.js 中解码 Base64 字符串)
      2. <i id='wS0lE'><tr id='wS0lE'><dt id='wS0lE'><q id='wS0lE'><span id='wS0lE'><b id='wS0lE'><form id='wS0lE'><ins id='wS0lE'></ins><ul id='wS0lE'></ul><sub id='wS0lE'></sub></form><legend id='wS0lE'></legend><bdo id='wS0lE'><pre id='wS0lE'><center id='wS0lE'></center></pre></bdo></b><th id='wS0lE'></th></span></q></dt></tr></i><div id='wS0lE'><tfoot id='wS0lE'></tfoot><dl id='wS0lE'><fieldset id='wS0lE'></fieldset></dl></div>

          <small id='wS0lE'></small><noframes id='wS0lE'>

        • <tfoot id='wS0lE'></tfoot>
                <tbody id='wS0lE'></tbody>
                <bdo id='wS0lE'></bdo><ul id='wS0lE'></ul>

              • <legend id='wS0lE'><style id='wS0lE'><dir id='wS0lE'><q id='wS0lE'></q></dir></style></legend>

                  本文介绍了在 node.js 中解码 Base64 字符串的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在尝试解码表示存储在数据库中的图像的 base64 字符串.我尝试了 SO 上提供的许多库和解决方案,但我仍然无法正确解码图像.特别是,使用以下代码:

                  I'm trying to decode a base64 string representing an image stored in a db. I tried many libraries and solutions provided on SO, but I'm still unable to decode the image correctly. In particular, using the following code:

                  var img = new Buffer(b64, 'base64').toString('ascii');
                  

                  我得到了一个类似的二进制表示,除了第一个字节.这是 base64 字符串的初始部分:

                  I get a similar binary representation, except for the first bytes. This is the initial part of the base64 string:

                  /9j/4RxVRXhpZgAASUkqAAgAAAANADIBAgAUAAAAqgAAACWIBAABAAAAiwYAABABAgAIAAAAvgAA
                  

                  这里是原始图像的前 50 个字节:

                  Here are the first 50 bytes of the original image:

                  ffd8ffe11c5545786966000049492a00080000000d003201020014000000aa00000025880400010000008b06000010010200
                  

                  这是我用 javascript 得到的字符串的前 50 个字节:

                  And here are the first 50 bytes of the string I get with javascript:

                  7f587f611c5545786966000049492a00080000000d0032010200140000002a00000025080400010000000b06000010010200
                  

                  你可以看到,这两个字符串是相同的,除了前 3 个字节和中间的几个字节.
                  有人可以帮我理解为什么会发生这种情况以及如何解决吗?谢谢

                  How you can see, the two strings are identical except for the fisrt 3 bytes and some few bytes in the middle.
                  Can somebody help me understand why this is happening and how to solve it? Thanks

                  推荐答案

                  问题是您正在尝试将二进制数据转换为 ASCII,这很可能意味着数据丢失,因为 ASCII 仅包含值 0x00-0x7F.所以当转换发生时,所有大于 0x7F 的字节都被限制为 0x7F.

                  The problem is that you're trying to convert binary data to ASCII, which most likely than not, will mean loss of data since ASCII only consists of values 0x00-0x7F. So when the conversion takes place, all bytes > 0x7F are capped at 0x7F.

                  如果您改为这样做,您可以看到数据与原始图像的前 50 个字节匹配:

                  If you do this instead, you can see the data matches your first 50 bytes of the original image:

                  console.log(Buffer.from(b64, 'base64').toString('hex'));
                  

                  但是如果你想保持二进制数据完整,只需将它作为一个Buffer实例而不调用.toString(),因为许多处理二进制数据的函数都可以处理Buffers(例如fs 核心模块).

                  But if you want to keep the binary data intact, just keep it as a Buffer instance without calling .toString(), as many functions that work with binary data can deal with Buffers (e.g. fs core module).

                  这篇关于在 node.js 中解码 Base64 字符串的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Fetch multiple links inside foreach loop(在 foreach 循环中获取多个链接)
                  Backbone Fetch Request is OPTIONS method(Backbone Fetch Request 是 OPTIONS 方法)
                  Fetch API leaks memory in Chrome(Fetch API 在 Chrome 中泄漏内存)
                  How can I download and save a file using the Fetch API? (Node.js)(如何使用 Fetch API 下载和保存文件?(Node.js))
                  Send blob data to node using fetch, multer, express(使用 fetch、multer、express 将 blob 数据发送到节点)
                  Sending a custom User-Agent string along with my headers (fetch)(发送自定义用户代理字符串以及我的标头(获取))

                  <small id='TUPS7'></small><noframes id='TUPS7'>

                    <tbody id='TUPS7'></tbody>
                    <bdo id='TUPS7'></bdo><ul id='TUPS7'></ul>

                  • <tfoot id='TUPS7'></tfoot>
                    <i id='TUPS7'><tr id='TUPS7'><dt id='TUPS7'><q id='TUPS7'><span id='TUPS7'><b id='TUPS7'><form id='TUPS7'><ins id='TUPS7'></ins><ul id='TUPS7'></ul><sub id='TUPS7'></sub></form><legend id='TUPS7'></legend><bdo id='TUPS7'><pre id='TUPS7'><center id='TUPS7'></center></pre></bdo></b><th id='TUPS7'></th></span></q></dt></tr></i><div id='TUPS7'><tfoot id='TUPS7'></tfoot><dl id='TUPS7'><fieldset id='TUPS7'></fieldset></dl></div>

                          1. <legend id='TUPS7'><style id='TUPS7'><dir id='TUPS7'><q id='TUPS7'></q></dir></style></legend>