post方式返回文件流实现前端blob下载,responseType: ‘blob‘无效

responseType: 'blob'

一般情况下,下载分为好几种,但是常用的是get下载文件流直接下载

post下载文件流是很少见的,但是鉴于参数太多,不能走get 只能走post下载,post下载分为两种:

1.form表单下载

2.post返回文件流转成blob下载,研究了很久 也很坑,上代码:

这个地方如果responseType设为blob的话,返回的文件流将会被转成blob对象,不是文件流,但是无论怎么设置都没有转成blob对象,网上有很多解释,

一个是说封装好的axios设置responseType是无效的,于是乎,我就引入了原生axios,手动添加token认证和content-type,但是返回结果依然是文件流,兜兜转转后来才发现最坑的是mockjs的引入,mockjs会影响responseType的设置转换,项目中注释掉mockjs即可实现成功blob的转换,还有就是可以修改mockjs的原生代码,如果需要用到mockjs的简友们可以修改代码,不过偶同步更新依赖包的时候记得及时修改,如果mockjs可以在项目中抛弃的话建议直接main.js中删除引入,毕竟还有其他的坑.

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值