首页 > 其他分享 >Vue.js组件开发-实现后端返回二进制文件在浏览器自动下载

Vue.js组件开发-实现后端返回二进制文件在浏览器自动下载

时间:2025-01-17 23:01:36浏览次数:3  
标签:文件 Vue 浏览器 URL js 二进制 axios Blob 下载

在Vue.js组件开发中,若需实现从后端获取二进制文件并触发浏览器自动下载,可以利用axios(或其他HTTP客户端库)来向后端发送请求,随后利用Blob对象及URL.createObjectURL方法生成一个可供下载的链接,最后通过创建一个隐藏的<a>元素或利用window.location来启动下载。

步骤

‌1.发送请求获取二进制数据‌:

利用axios向后端API发送请求,并指定responseType为blob以获取二进制数据。

2‌.创建Blob对象‌:

接收到的二进制数据将作为Blob对象返回,可用它来生成文件。

3‌.生成下载链接‌:

借助URL.createObjectURL方法,为Blob对象创建一个临时的URL。

4‌.触发下载‌:

通过创建一个隐藏的<a>元素,设置其href属性为上述临时URL,并调用click方法以启动下载。或者,也可以直接将window.location指向该URL来下载文件,但这种方法可能无法设置文件名。

‌5.清理工作‌:

下载完成后,应调用URL.revokeObjectURL来释放之前创建的临时URL,避免内存泄漏。

示例

<template>
  <div>
    <button @click="downloadFile">点击下载文件</button>
  </div>
</template>

<script>
import axios from 'axios';

export default {
  methods: {
    async downloadFile() {
      try {
        // 向后端发送请求以获取二进制文件数据
        const response = await axios.get('你的后端API地址', {
          responseType: 'blob' // 关键:指定返回类型为blob
        });

        // 从响应中提取Blob对象
        const blob = response.data;

        // 为Blob对象创建一个临时的下载URL
        const downloadUrl = URL.createObjectURL(blob);

        // 创建一个隐藏的<a>元素并触发下载
        const a = document.createElement('a');
        a.href = downloadUrl;
        // 可根据需要设置下载文件的名称
        a.download = '你的文件名.ext'; 
        document.body.appendChild(a);
        a.click();

        // 清理工作:从DOM中移除<a>元素,并释放临时URL
        document.body.removeChild(a);
        URL.revokeObjectURL(downloadUrl);
      } catch (error) {
        console.error('文件下载失败:', error);
      }
    }
  }
};
</script>

注意

‌CORS(跨域资源共享)‌:
若前端与后端部署在不同的域上,请确保后端已正确配置CORS,以允许前端跨域请求二进制文件。

‌文件名设置‌:
在创建<a>元素时,可通过设置download属性来指定下载文件的名称。若未设置,浏览器可能会使用URL的最后一部分作为默认文件名。

‌错误处理‌:
应添加适当的错误处理逻辑,以处理请求失败、网络中断等异常情况。

‌安全性‌:
确保从后端获取的文件数据是安全的,特别是当文件内容可能由用户生成或上传时。

标签:文件,Vue,浏览器,URL,js,二进制,axios,Blob,下载
From: https://blog.csdn.net/michael_jovi/article/details/145216059

相关文章

  • js逆向笔记 绕过某网站开发者工具检测
    js逆向笔记绕过某网站开发者工具检测在这篇博客中,我将分享我在逆向分析爱企查时的一些发现与绕过技巧。最开始,我是偶然发现了这个网站,它在正常使用浏览器按下F12打开开发者工具时,似乎有某种方式禁用了开发者工具。不过,我没有放弃,继续从浏览器的右上角点击手动打开开发者......
  • node.js在线学习系统程序+论文 可用于毕业设计
    本系统(程序+源码+数据库+调试部署+开发环境)带文档lw万字以上,文末可获取源码系统程序文件列表开题报告内容选题背景关于在线学习系统的研究,现有研究主要以系统的部分功能优化、特定课程的线上教学实践为主。在国外,一些发达国家早已开展在线学习系统的建设与应用,取得了显著......
  • Vue2+OpenLayers实现添加多边形覆盖物(提供Gitee源码)
    目录一、案例截图二、安装OpenLayers库三、代码实现3.1、初始化变量3.2、实现一个自定义面3.3、创建多边形图层3.4、创建点位3.5、更新多边形显示3.6、开始绘制/结束绘制3.7、创建/更新虚线显示3.8、初始化地图事件3.9、完整代码四、Gitee源码一、案例截图二......
  • THREE.js学习笔记8——Textures
    这个小节主要学习纹理,Texture纹理是覆盖几何形状表面的图像,不同类型的纹理具有多种不同的效果。这些纹理(尤其是金属性和粗糙度)遵循PBR原则基于物理的渲染许多技术往往遵循现实生活中的方向以获得现实的结果成为现实渲染的标准许多软件、引擎和库都在使用它如何加载纹理?......
  • springboot小程序 uniapp基于Vue宏飞数码好物分享系统实现
    文章目录项目和技术介绍具体实现截图uniapp+hbuilderx错误处理和异常处理小程序框架以及目录结构介绍系统安全性java类核心代码部分展示软件测试数据完整性源码获取/详细视频演示项目和技术介绍微信开发者工具/hbuiderx后端语言支持以下技术栈:1java(SSM/springbo......
  • 【华为OD-E卷 - 数组连续和 100分(python、java、c++、js、c)】
    【华为OD-E卷-数组连续和100分(python、java、c++、js、c)】题目给定一个含有N个正整数的数组,求出有多少个连续区间(包括单个正整数),它们的和大于等于x输入描述第一行两个整数Nx(0<N<=100000,0<=x<=10000000)第二行有N个正整数(每个正整数小于等于100)输出......
  • wx028基于springboot+vue+uniapp的网上花店小程序
    开发语言:Java框架:springboot+uniappJDK版本:JDK1.8服务器:tomcat7数据库:mysql5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:Maven3.3.9系统展示鲜花列表公告信息管理公告类型管理鲜花管理公告管理摘要网上花店微信小程序分为管理员还......
  • 基于springboot+vue的个性化旅游推荐系统的设计与实现
    开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:Maven3.3.9系统展示系统首页旅游景点个人中心管理员登录管理员功能界面用户界面旅游景点界面酒店信息界面旅游......
  • JS — 对象、数组、函数
    对象英文名称:Object。类似于C++中的map,python中的字典,由key:value对构成。value可以是变量、数组、对象、函数等。函数定义中的this用来引用该函数的“拥有者”。例如:test.js中的内容为:letperson={//定义一个对象personname:'kitty',//对象的元......
  • 基于java的SpringBoot/SSM+Vue+uniapp的高校校园招聘服务系统的详细设计和实现(源码+l
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......