有关后端返回文件流或base64文件,前端如何实现图片展示和下载 ...

王柳  金牌会员 | 2024-6-11 08:22:26 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 890|帖子 890|积分 2670

后端返回的文件流,前端怎么把图片显示出来

 1.多年前端开发经验的我现在用的最多的是:直接将请求地址写在src里面,如:
<img src="/file/preview/picture.png" alt="图片">
 2.由于后台加上鉴权后,需要每个接口在header里面加上token,上面的做法就行不通了,需要发送请求获得文件流
  1. const file_data = res.data // 后端返回的文件流
  2. const blob = new Blob([file_data])
  3. const url = window.URL.createObjectURL(blob) // image中src的链接
复制代码
3.后台返回base64文件
  1. srcurl= 'data:application/octet-stream;base64,' + res
复制代码
js下载后端返回的文件

1.后端返回文件流形式,前端下载
  1. // res 为后端返回的响应对象
  2. const file_data = res.data // 后端返回的文件流
  3. const blob = new Blob([file_data])
  4. const url = window.URL.createObjectURL(blob) // 创建下载的链接
  5. const file_name = decodeURI(res.headers['content-disposition'].replace('attachment;filename=', '')) // 需要后端暴露请求头'Content-Disposition'
  6. console.log(file_name) // 从请求头获取文件名
  7. const downloadElement = document.createElement('a')
  8. downloadElement.style.display = 'none'
  9. downloadElement.href = url
  10. downloadElement.download = file_name // 下载后文件名
  11. document.body.appendChild(downloadElement)
  12. downloadElement.click()
  13. document.body.removeChild(downloadElement) // 下载完成移除元素
  14. window.URL.revokeObjectURL(url) // 释放掉blob对象
  15. 注:如果下载文件变大打不开,可以设置 responseType: 'arraybuffer'
  16. async reqestApi(param) {
  17.     const res = await axios.get('exportExeclData', { params: param, responseType: 'arraybuffer' })   
  18. }
复制代码
2.后端返回base64格式,前端下载
  1. // res 后端返回的文件base64
  2. const link = document.createElement('a')
  3. link.href = 'data:application/octet-stream;base64,' + res
  4. link.download = '下载的文件名'
  5. link.click()
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

王柳

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表