【vue3+ts】根据后端返回内容进行pdf下载,下载后点击查看需要输入密码的问题

1、问题: 

 下载后的pdf点开是这个页面

 经过查找原因后是在发送请求下载 PDF 文件时,如果不指定响应类型为 blob,服务器返回的数据可能会被浏览器视为普通的文本数据,而不是二进制数据。这可能会导致浏览器在尝试打开 PDF 文件时出现密码输入框的情况。

通过指定 responseType 为 'blob',您告诉 Axios 期望接收一个二进制数据的响应。这样浏览器就能正确处理这个二进制数据,而不会将其视为文本数据。

2、代码:

api.ts

//在发送请求时指定响应类型
export const exportOrder=()=>request.get(`/backstage/api/order/morder.php`,{responseType: 'blob'})

 xxx.vue

//点击导出按钮触发的方法
const exportOrders=async ()=>{
  let res=await exportOrder()
  // 创建一个可下载的链接
  const url = window.URL.createObjectURL(new Blob([res], { type: 'application/pdf' }));
  // 创建一个链接元素并模拟点击下载
  const a = document.createElement('a');
  a.href = url;
  a.download =  `order-${year.value}-${month.value}-${day.value}.pdf`; // 可以根据实际情况指定文件名
  document.body.appendChild(a);
  a.click();
  // 释放URL对象
  window.URL.revokeObjectURL(url);
  ElMessage.success('订单导出成功')
}

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值