vue项目用Electron打包后导出文件的文件名获取不到

需求:Vue的项目导出表格,文件名根据后端返回的名字进行导出。

  • 文件名在后端返回的响应头中获取
const contentDisposition = response.headers['content-disposition']
let fileName = contentDisposition.split('filename=')[1];
const link = document.createElement('a');
link.style.display = 'none';
//设置连接
link.href = URL.createObjectURL(new Blob([response.data]));
link.download = decodeURI(fileName); 
document.body.appendChild(link);
//模拟点击事件
link.click();

在浏览器中导出文件名正常导出;

  • 用Electron打包成Exe程序后,导出文件的文件名消失了,排查问题发现是header头中打印的时候获取不到“content-disposition”,但是看接口的响应头里有该字段。
  • 解决办法:后端设置
  response.setHeader("Access-Control-Expose-Headers", "Content-Disposition")
  response.setHeader("Content-Disposition", ...)

默认情况下,header只有六种 simple response headers (简单响应首部)可以暴露给外部:

  • Cache-Control
  • Content-Language
  • Content-Type
  • Expires
  • Last-Modified
  • Pragma
    这里的暴露给外部,意思是让客户端可以访问得到,既可以在Network里看到,也可以在代码里获取到他们的值。
    上面问题提到的content-disposition不在其中,所以即使服务器在协议回包里加了该字段,但因没“暴露”给外部,客户端就“看得到,吃不到”。
    而响应首部 Access-Control-Expose-Headers 就是控制“暴露”的开关,它列出了哪些首部可以作为响应的一部分暴露给外部。
    所以如果想要让客户端可以访问到其他的首部信息,服务器不仅要在heade里加入该首部,还要将它们在 Access-Control-Expose-Headers 里面列出来。**

原文链接:https://blog.csdn.net/weixin_46574499/article/details/125476080

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值