Javascript 无法从NodeJS中的base64生成映像

Javascript 无法从NodeJS中的base64生成映像,javascript,node.js,google-contacts-api,google-photos,Javascript,Node.js,Google Contacts Api,Google Photos,这是我从google api联系人照片中得到的字节数组响应: console.log('byteArray:',res1.body) ����JFIF��``"����? !1AQaq2B���"#RT����br��3����������0 !1A2Qaq�"��BRS����� ?���Kѐ�V��,���fu0�AկQ�w���y�

这是我从google api联系人照片中得到的字节数组响应:

console.log('byteArray:',res1.body)

 ����JFIF��``"����?  !1AQaq2B���"#RT����br��3����������0    !1A2Qaq�"��BRS�����
                                                                     ?���Kѐ�V��,���fu0�AկQ�w���y�
                                                                                                        x��i�|��F?���;҆�X����������(+:s��iud���c�Gf�e7�jI�;N�d�%�f����+�Uh4q;Ĭ!9ȨD��[��5�ކ�;h��gCt�͌��و1J��q�a��S��^�V��R�����U��K6�<��"�U��~"u�|Q
ڵ��G���;}�ђ׊��<���sX���>j���hk���~+�^����3�q4��P؝�oZ������4��P{O-j�]�d�c��pG��<7��Q������zd{n��|�`�mɊ��SN�D����}�Hv��0PY�<\�#�T�k!0�R(�Um�n��e�>�a욶˽�8P����{�)���"�
�4��}����6�`���T��!wY�� ��4�y�����+�A]U�M�ֻ⼪�d�N��EcQ`a�u�R��
                                                                  �
                                                                   Z"�e/���;-�vL�<c���IH"W2Ga���Ӄ⬨�cݻ#q��c�Y䣃F�G�$�0:�z�"   1��
                                                                                                                                   �S�R�WCh��a���@%#��$�i�y�
            u��[�6Ή����(c�Sw˻�G��X3����R��n'�m+>����'
                                                        �/;�%�k�4��Z�/l^�z�/l^�z��Z�}k^��!������O����������Dzx�"��>��û#>�#\~{�L-D�k��T�L�����({�TAr9����g}׎��y�{Լ�.�у�8���^��6��"9+��k��K�V�6�����p�¦�Y�~%b�F�lX����_���v����_�O����A�+�G��e]Q*���z��G|�Y{��f��Y�CI�qu*p�v�T�Z�%*R�Kx��c��Is�D�Y�-���O$��!�`��4M���VX�@v�g��U�̦��2E�W��s�7=}z#��Ԯ� c���t^��n|R2H΋�� |�����w�k�9��ٵ�o1�U��nC�r@���7���wZ��-�!n����v�p���P�h_dR�����O5�ޟ�
�*"̙����7-rr�{��<��3��#O�S;:/~�"f~Ϋ;IǸ,�V�[K�\���՗c���d4`6��ѣ��Õ]<ϚN��<��r/Fug<֧���ӢуZ�>z�Cܟ{'c��ˏO��jB��o �����c5�:�6:H�Ώ�c�S<�}{���U_c+�T��D����JY�����=v�&5� �ג3䒮i�Wq�#�$J  �ǖ+��4"�FZ��ʗ���ݹ�E�]tV��
!� ��H�Op��)�&���P۷��'�;S�������#�!��/X��GO��iC�8>ȅ:���`$���H��m
这将生成以下base64:

'',
但是,将其指定给
不会生成图像

以下是google api示例:


我做错了什么?

JFIF
表明您实际上是在转换.jpg文件,而不是.png文件

确保文件类型(如.png)与Mime类型(如“image/png”)匹配

也考虑指定字符集。

建议更改:

base64Image = new Buffer.from(res1.body).toString('base64');
console.log("data:image/jpeg;charset=utf-8;base64," + base64Image;)
<= Assuming it's really a jpeg file
   Don't forget to make the corresponding change in your HTML, too...
base64Image=newbuffer.from(res1.body).toString('base64');
log(“数据:image/jpeg;字符集=utf-8;base64,”+base64Image;)

JFIF
表明您实际上是在转换.jpg文件,而不是.png文件

确保文件类型(如.png)与Mime类型(如“image/png”)匹配

也考虑指定字符集。

建议更改:

base64Image = new Buffer.from(res1.body).toString('base64');
console.log("data:image/jpeg;charset=utf-8;base64," + base64Image;)
<= Assuming it's really a jpeg file
   Don't forget to make the corresponding change in your HTML, too...
base64Image=newbuffer.from(res1.body).toString('base64');
log(“数据:image/jpeg;字符集=utf-8;base64,”+base64Image;)

当您尝试仅获取一个请求而不指定来自第三方的图像的编码类型时,主体的响应将是您在bytearray变量中获取的原始数据,因此您需要添加头
编码:“binary”
因此,响应将以二进制格式出现,然后您可以使用
缓冲区
缓冲区。从
将二进制数据转换为base64,并在

function getImage(imageUrl) {
var options = {
    url: `${imageUrl}`,
    encoding: "binary"
};

    request.get(options, function (err, resp, body) {
        if (err) {
            reject(err);
        } else {
            var prefix = "data:" + resp.headers["content-type"] + ";base64,";
            var img = new Buffer(body.toString(), "binary").toString("base64");//  var img = new Buffer.from(body.toString(), "binary").toString("base64");
            dataUri = prefix + img;
            console.log(dataUri);
        }
    })
}
什么时候使用承诺

function getImage(imageUrl) {
var options = {
    url: `${imageUrl}`,
    encoding: "binary"
};
  return new Promise(function (resolve, reject) {
    request.get(options, function (err, resp, body) {
        if (err) {
            reject(err);
        } else {
            var prefix = "data:" + resp.headers["content-type"] + ";base64,";
            var img = new Buffer(body.toString(), "binary").toString("base64");//  var img = new Buffer.from(body.toString(), "binary").toString("base64");
            dataUri = prefix + img;
            console.log(dataUri); 
            resolve(dataUri);
        }
    })
})}
这个表单还有一个节点模块,我从中得到了解决方案
https://www.npmjs.com/package/imageurl-base64

如果您想从本地磁盘读取映像,
fs
模块将帮助您

 var prefix = "data:" + "content-type" + ";base64,";
 img: fs.readFileSync(`pathtothelocalimage`, 'base64')
 //img: fs.readFile(`pathtothelocalimage`, 'base64')
 dataUri = prefix + img;

当您尝试仅获取一个请求而不指定来自第三方的图像的编码类型时,主体的响应将是您在bytearray变量中获取的原始数据,因此您需要添加头
编码:“binary”
因此,响应将以二进制格式出现,然后您可以使用
缓冲区
缓冲区。从
将二进制数据转换为base64,并在

function getImage(imageUrl) {
var options = {
    url: `${imageUrl}`,
    encoding: "binary"
};

    request.get(options, function (err, resp, body) {
        if (err) {
            reject(err);
        } else {
            var prefix = "data:" + resp.headers["content-type"] + ";base64,";
            var img = new Buffer(body.toString(), "binary").toString("base64");//  var img = new Buffer.from(body.toString(), "binary").toString("base64");
            dataUri = prefix + img;
            console.log(dataUri);
        }
    })
}
什么时候使用承诺

function getImage(imageUrl) {
var options = {
    url: `${imageUrl}`,
    encoding: "binary"
};
  return new Promise(function (resolve, reject) {
    request.get(options, function (err, resp, body) {
        if (err) {
            reject(err);
        } else {
            var prefix = "data:" + resp.headers["content-type"] + ";base64,";
            var img = new Buffer(body.toString(), "binary").toString("base64");//  var img = new Buffer.from(body.toString(), "binary").toString("base64");
            dataUri = prefix + img;
            console.log(dataUri); 
            resolve(dataUri);
        }
    })
})}
这个表单还有一个节点模块,我从中得到了解决方案
https://www.npmjs.com/package/imageurl-base64

如果您想从本地磁盘读取映像,
fs
模块将帮助您

 var prefix = "data:" + "content-type" + ";base64,";
 img: fs.readFileSync(`pathtothelocalimage`, 'base64')
 //img: fs.readFile(`pathtothelocalimage`, 'base64')
 dataUri = prefix + img;

如何指定字符集?进行了更改但仍无法生成图像:(如何指定字符集?进行了更改但仍无法生成图像):(