vue 后端返回二进制流-前端通过blob对象下载文件-图片

这篇具有很好参考价值的文章主要介绍了vue 后端返回二进制流-前端通过blob对象下载文件-图片。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

  • 在实际开发中我们经常会遇见下载文件的场景,比如下载合同,下载文件

  • 下载文件有2种方式,一种是后端返回二进制流,前端通过blob对象接受根据不同类型下载

  • 还有一种把地址直接在浏览器新窗口打开浏览器打开pdf可以预览和下载,其他文件直接下载

  • 但不管是那种方式,原理都是一样的只是取决于谁来执行转化代码

代码实现

1.封装api-根据直接后端接口而定(注意要在请求时标明是二进制文件流)

// 文件-图片下载
export function downloadfile (data) {
  return request({
    url: '/download/file',
    method: 'post',
    data,
    // 指定请求类型为二进制流
    // 不写可能会造成下载成功的图片和文件是看不到和没有内容的
    responseType: 'blob'
  })
}

2.下载不同文件和图片在项目中可能经常使用-可以封装成一个方法。

2.1在utils下创建download.js文件

export default {
    // 下载 Excel 方法
    excel (data, fileName) {
      this.download(data, fileName, 'application/vnd.ms-excel')
    },
  
    // 下载 Word 方法
    word (data, fileName) {
      this.download(data, fileName, 'application/msword')
    },
  
    // 下载 Zip 方法
    zip (data, fileName) {
      this.download(data, fileName, 'application/zip')
    },
  
    // 下载 Html 方法
    html (data, fileName) {
      this.download(data, fileName, 'text/html')
    },
  
    // 下载 Markdown 方法
    markdown (data, fileName) {
      this.download(data, fileName, 'text/markdown')
    },
  
    // 下载 pdf 方法
    pdf (data, fileName) {
      console.log('data', data)
      console.log('fileName', fileName)
      this.download(data, fileName, 'application/pdf')
    },
  
    // 下载 图片方法
    png (data, fileName) {
      this.download(data, fileName, 'application/png')
    },
  
    // 兼容写法
    stream (data, fileName) {
      this.download(data, fileName, 'application/octet-stream')
    },
  
    download (data, fileName, mineType) {
      // 创建 blob对象
      let blob = new Blob([data], { type: mineType })
      // 浏览器api 有的不支持-二种都写
      window.URL = window.URL || window.webkitURL
      // 获取链接地址-(内容赋值到临时链接)
      let href = URL.createObjectURL(blob)
      // 创建a标签
      let downA = document.createElement('a')
      // 把链接赋值给a标签
      downA.href = href
      // 赋值文件名称
      downA.download = fileName
      // 点击下载
      downA.click()
      // 销毁超连接
      window.URL.revokeObjectURL(href)
    }
  }

3.在页面中使用

// html
<el-button type="info" @click="addclose">下载</el-button>
​
// data
datafile: {
        url: '文件或者图片地址'
      }
      
// 引入方法
import download from '@/utils/download'
// 方法
// 下载
    async addclose () {
      const res = await downloadfile(this.datafile)
​
      // 下载图片
      // 针对性的类型-名称带不带.png都不会受影响
      // download.png (res,'测试图片')
      // 带后缀
      // download.png (res,'测试图片.png')
​
      // 下载pdf文件
      // 针对性的类型-名称带不带.pdf都不会受影响
      // download.pdf (res,'pdf文件')
      // 带后缀
      download.pdf (res,'pdf文件.pdf')
​
      // 公共方法
      // application/octet-stream 相当于公共类型-需要在名称带上指定的后缀-不然下载下来的文件没有后缀名打不开
      // download.stream (res,'公共方法.png')
      // download.stream (res,'公共方法.pdf')
    }

注意

  • 首先排查下载下来的文件格式是否正确,不正确检查blob对象类型(名称也有关系是否带后缀名)

  • 如果发现下载下来的文件格式后缀正确,内容,图片为空,看不见,排查后端是否把内容转成流,前端在封装api时是否设置responseType: 'blob'​


总结:

经过这一趟流程下来相信你也对 vue 后端返回二进制流-前端通过blob对象下载文件-图片 有了初步的深刻印象,但在实际开发中我 们遇到的情况肯定是不一样的,所以我们要理解它的原理,万变不离其宗。加油,打工人!

什么不足的地方请大家指出谢谢 -- 風过无痕文章来源地址https://www.toymoban.com/news/detail-752096.html

到了这里,关于vue 后端返回二进制流-前端通过blob对象下载文件-图片的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【JavaScript】后端返回的二进制流音频数据或本地音频资源,前端如何播放?

    如果我们要使用本地的音频资源,在 vue3 中那么我们需要对资源的地址做一下处理 后端返回二进制流音频数据,怎么让其可播放 前端播放二进制语音流

    2024年02月03日
    浏览(46)
  • 微信小程序微信原生小程序如何通过后端返回的二进制流导出excel文件并保存和转发

    首先后端返回给我们的数据是这样的,一串二进制流 然后直接上代码吧,注释基本上说的差不多了 打开后的界面就是这样,导出成功,然后右上角三个点可以保存本地和转发

    2024年02月11日
    浏览(40)
  • 通过 Blob 对二进制流文件下载实现文件保存下载

    原理 : 前端将二进制文件做转换 实现下载:请求后端接口-接收后端返回的二进制流(通过二进制流( Blob )下载, 把后端返回的二进制文件放在 Blob 里面)-再通过 file-saver 插件保存 需求背景 业务:下载模板文件 页面上使用: 保存文件: 发起请求通用方法(更改 axios 的 re

    2024年02月09日
    浏览(41)
  • 前端:JS:将图片转为二进制与其他文本传入后端

    在前端,可以将图片转换为二进制数据,并将其与其他文本字符串一起发送到后端。一种常见的方法是将所有数据组合为一个 FormData 对象,然后通过 AJAX 或 Fetch API 将其发送给后端。以下是一个示例: 解释 : 当文件输入框内容发生变化时,会触发 change 事件。然后,它会读

    2024年04月26日
    浏览(28)
  • html 二进制 blob 给图片赋值

    1、html 二进制流 (非base64),给图片赋值             var reader = new FileReader();             reader.onload = function (e) {               var img = document.querySelector(\\\'#canvas_img\\\');               img.src = e.target.result;             };             // data 二进流             reader.readAs

    2023年04月21日
    浏览(36)
  • uniapp小程序中处理blob二进制流数据

    小程序中是不支持blob格式数据的,new Blob()会报错Blob未定义 处理方法是转成base64格式: 首先,请求中要带上responseType: \\\"arraybuffer\\\",保证返回的数据格式是arraybuffer 使用uni.arrayBufferToBase64() 转化成base64格式,后续根据业务处理数据即可。 在这个代码中,数据是一张png格式的二维

    2024年02月04日
    浏览(37)
  • 文件流互相转换(blob转base64,二进制流)

    跟用input上传文件的获取到的差不多 用URL.createObjectURL(blob)转化后是这样

    2024年02月10日
    浏览(35)
  • vue如何通过$http的post方法请求下载二进制的Excel文件

    使用此function 使用此function, test.vue instanceName: \\\"exportExcel\\\",导出excel文件 instanceName: \\\"downloadLog\\\",下载.log后缀的txt文件 封装接口 代码中使用:

    2024年01月18日
    浏览(37)
  • 微信小程序获取后台返回的二进制图片

    获取后台返回的二进制图片需要先使用wx.request方法发起网络请求获取图片数据,然后将返回的数据用wx.arrayBufferToBase64方法进行转换,最后将转换后的数据绑定到图片的src属性即可。 参考代码如下 其中,url为后台返回的图片地址,responseType为返回的数据类型为二进制数组。在

    2024年02月10日
    浏览(39)
  • html2canvas生成图片地址Base64格式转成blob在转成file(二进制)可正常发送(保姆教程,复制粘贴可用)

    开始:                                                  最终结果:                                                      1. html2canvas方法生成的图片地址已Base64编码形式放在img标签src中可直接展示生成的图片(注意 页面标签获取位置 ,还有个 setTimeout 页面渲染需要

    2024年02月13日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包