node端将二进制文件从后端获取到并转换成base64发送给前端

遇到了一个场景:用node做中间件,后端传过来了一个图片的二进制流,需要node端对其转码成base64再传给前端

错误写法:

const res = await netWork.get('/auth/verifycode')//传输后端的网络请求 得到二进制文件
let imgPrefix = `data:image/${imgType};base64,`
let buffer = new Buffer(res.data).toString('base64')
let imgUrl = imgPrefix+buffer
throw new Success(imgUrl)

这个写法,虽然可以得到base64,但是无法显示,因为格式有误,原因如下:

在我们发送一个http请求的时候,可以限制返回时的responseType,默认为document 问题就出在这个document上

我们的二进制字符串在res.data得到的时候已经被转成字符串了,此时已经进行了一个转码,把这个已经改变了的字符串再转换成buffer,然后再转成base64,自然是没有办法得到正确的图片的

如果要得到正确的图片 我们需要加上responseType:‘arraybuffer’,加上之后返回的data就是一个buffer数组,这个数组是直接由二进制转换得到的,没有经过二次转码,然后使用toString(‘base64’),即可得到正确的图片

代码如下:

const imgType = 'png'
  const res = await netWork.get('/auth/verifycode',{
    responseType: "arraybuffer"//很重要
  })
  let imgPrefix = `data:image/${imgType};base64,`
  let imgUrl = imgPrefix+res.data.toString('base64')
  throw new Success(imgUrl)
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值