开发避坑指南(70):Vue3 Http请求头携带token下载pdf文件解决方案

问题

Vue3中http请求如何下载预览pdf文件?请求头中如何携带token?

解决办法

使用axios下载PDF文件,通过Blob对象处理二进制数据流实现。请求头中携带token则通过在axios请求中添加headers实现。代码如下:

1、main.js中全局引入axios或则vue组件中单独引入axios

vue 复制代码
import axios from 'axios'

2、使用axios发送下载请求

vue 复制代码
axios({
  method: 'get', // 使用GET请求方法
  responseType: 'blob', // 指定响应数据类型为二进制大对象(Blob),用于处理文件流
  url: url, // 请求的PDF文件URL地址
  headers: {
    'X-Auth-token': token // 在请求头中添加认证token,用于身份验证
  }
}).then(res => {
  // 将接收到的二进制数据创建为Blob对象,使用响应头中的content-type指定文件类型
  const blob = new Blob([res.data], { type: res.headers["content-type"] });
  
  // 浏览器兼容性处理:优先使用标准URL接口,回退到webkitURL(兼容旧版浏览器)
  var URL = window.URL || window.webkitURL;
  
  // 为Blob对象创建临时URL链接,可用于文件访问
  let href = URL.createObjectURL(blob);
  
  // 在新窗口或标签页中打开PDF文件进行预览
  window.open(href)
});
相关推荐
一水鉴天20 小时前
整体设计 定稿 之24+ dashboard.html 增加三层次动态记录体系仪表盘 之2 程序 (Q208 之2)
开发语言·前端·javascript
JIngJaneIL21 小时前
基于Java饮食营养管理信息平台系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
IT_陈寒21 小时前
Java 21新特性实战:这5个改进让我的代码效率提升40%
前端·人工智能·后端
肠胃炎21 小时前
Chrome扩展截图功能实现
前端·chrome
老华带你飞21 小时前
垃圾分类|基于springboot 垃圾分类系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
二狗哈21 小时前
Cesium快速入门17:与entity和primitive交互
开发语言·前端·javascript·3d·webgl·cesium·地图可视化
xingzhemengyou121 小时前
python datetime模块使用
前端·python
GISer_Jing21 小时前
AI驱动营销增长:7大核心场景与前端实现
前端·javascript·人工智能
T___T1 天前
Vue 3 做 todos , ref 能看懂,computed 终于也懂了
前端·javascript·面试
bug总结1 天前
vue+A*算法+canvas解决自动寻路方案
前端·vue.js·算法