将Baseios编码后的axios图像流转换为字符串吗?

问题描述 投票:0回答:1

到目前为止,我有这个:

const Fs = require('fs')  
const Path = require('path')  
const Axios = require('axios')
var {Base64Encode} = require('base64-stream');

const url = 'https://unsplash.com/photos/AaEQmoufHLk/download?force=true'

const response = await Axios({
      url,
      method: 'GET',
      responseType: 'stream'
    })

response.data.pipe(new Base64Encode())

此基数64对图像进行编码。我们如何将其转换为字符串。我尝试过这样的事情:

  function streamToString (stream) {
    const chunks = []
    return new Promise((resolve, reject) => {
      stream.on('data', chunk => chunks.push(chunk))
      stream.on('error', reject)
      stream.on('end', () => resolve(Buffer.concat(chunks).toString('utf8')))
    })
  }

const result = await streamToString(response.data.pipe(new Base64Encode()))

但是错误。有想法吗?

javascript node.js stream axios base64
1个回答
0
投票

在您的示例中,您使用了已经抽出字符串的Base64encode模块-从而使上面的示例失败(除非是由于顶层等待)。您实际上不需要将大块转换为字符串,因为它们已经是字符串,因此只需进行简单的串联即可。

实际上,仅使用node.js流,整个过程可能会简单10倍:

const Axios = require('axios')
const {PassThrough} = require("stream");

const url = 'https://unsplash.com/photos/AaEQmoufHLk/download?force=true';

(async function() {
    const response = await Axios({
        url,
        method: 'GET',
        responseType: 'stream'
    });

    // we just pipe the data (the input carries it's own encoding)
    // to a PassThrough node stream that outputs `base64`.
    const chunks = response.data
        .pipe(new PassThrough({encoding:'base64'}));

    // then we use an async generator to read the chunks
    let str = '';
    for await (let chunk of chunks) {
        str += chunk;
    }

    // et voila! :)
    console.log(str);
})();
© www.soinside.com 2019 - 2024. All rights reserved.