当前位置:首页 » 《我的小黑屋》 » 正文

前端下载后端返回的文件流,取请求头中的文件名称

4 人参与  2024年03月30日 16:45  分类 : 《我的小黑屋》  评论

点击全文阅读


 一、先尝试用普通方法调取后端接口

// 附件下载export function downloadPdfs(data) {  return request({    url: '/organizaitonApproval/downloadWord',    method: 'post',    data: data,    responseType: 'blob', // 需要加blob  })}

但是用上面的方法发现只能顺利下载文件,res.headers["content-disposition"] 取不到后端给前端返回的请求头。

通过问题排查发现:

如图,前端需要取的res.headersres.data 是一层的,当拦截器中返回res.data 后,就取不到外层的headers,因此前端要自己写axios请求方法

二、前端单独写axios请求方法

import { getToken } from "@/utils/auth";import axios from 'axios';axios.defaults.headers['Authorization'] = 'Bearer ' + getToken();axios.defaults.headers['Content-Type'] = 'application/json;charset=utf-8';

downloadFile(row) {      let data={        orgId: row.orgId      }      axios({          method: 'post',          url: '/organizaitonApproval/downloadWord',          data: data,          responseType: 'blob'        }).then((res) => {            // 文件流            const content = res;            const blob = new Blob([content]);            let url = window.URL.createObjectURL(blob);            let link = document.createElement("a");            link.style.display = "none";            link.href = url;            // 取后端给前端返的请求头中的文件名称            const temp =res.headers["content-disposition"].split(";")[1].split("filename=")[1];            console.log("temp:" + temp)                link.download = fileName            document.body.appendChild(link);            link.click();            document.body.removeChild(link); //下载完成移除元素            window.URL.revokeObjectURL(url); //释放掉blob对象      })      .catch(error => {        //console.log(error);      });    }

但是前端依旧拿不到 res.headers["content-disposition"] ,如图,headers里面没有content-disposition 属性

继续排查问题,发现后端没有给前端单独塞,需要找后端再改一下

三、后端需要给前端单独塞一个 Content-Disposition

response.setHeader("Access-Control-Expose-Headers","Content-Disposition");

拿到res.headers["content-disposition"] 后,发现此时temp是乱码,需要前端自己转一下。

四、未经过处理,直接拿到后端给前端的乱码filename

%E8%BD%AF%E4%BB%B6%E9%A1%B9%E7%9B%AE%E8%AE%A1%E5%88%92%E8%A1%A8.docx

五、前端文件乱码的转码方法

1、方法一:安装iconv-lite依赖

(1)下载模块包,使用npm install iconv-lite

(2)在项目中引入iconv-lite

import iconv from ‘iconv-lite’;

let iconv = require('iconv-lite'); iconv.skipDecodeWarning = true;//忽略警告let buf = iconv.decode(temp, 'gdk');const fileName = iconv.decode(buf, 'utf-8')console.log('fileName_',fileName)

2、方法二:采用后端java在响应头中的里设置文件名称(URLEncoder.encode)。前端vue,var fileName = decodeURIComponent(fileNameUtf8),进行解码。

前端代码如下:

downloadFile(row) {      let data={        orgId: row.orgId      }      axios({          method: 'post',          url: '/organizaitonApproval/downloadWord',          data: data,          responseType: 'blob'        }).then((res) => {            // 文件流            const content = res;            const blob = new Blob([content]);            let url = window.URL.createObjectURL(blob);            let link = document.createElement("a");            link.style.display = "none";            link.href = url;            // 取后端给前端返的请求头中的文件名称            const temp =res.headers["content-disposition"].split(";")[1].split("filename=")[1];            const fileName = decodeURIComponent(temp)            console.log("fileName:" + fileName)                link.download = fileName            document.body.appendChild(link);            link.click();            document.body.removeChild(link); //下载完成移除元素            window.URL.revokeObjectURL(url); //释放掉blob对象      })      .catch(error => {        //console.log(error);      });    }

我采用的第二种方法

<** ----------2023-06-16 ---------- *>

【注:方法一的“安装iconv-lite依赖”可能不行,今天想起来这个试了一下,发现依赖引入后,虽然解决了乱码的问题,但是会导致通过原有拦截器的文件下载全部报错,将该依赖卸载后,通过拦截器下载的文件恢复正常。所以最后还是得用方法二】

最后效果:

参考:解决前后端传送文件名,出现乱码问题,URLEncoder_urlencoder.encode 乱码-CSDN博客

axios获得文件流,转为blob,出现部分文件乱码问题解决思路_js请求后端的文件流转为blob之后变了-CSDN博客


点击全文阅读


本文链接:http://zhangshiyu.com/post/88264.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 祖母寿宴,侯府冒牌嫡女被打脸了(沈屿安秦秀婉)阅读 -
  • 《雕花锦年,昭都旧梦》(裴辞鹤昭都)完结版小说全文免费阅读_最新热门小说《雕花锦年,昭都旧梦》(裴辞鹤昭都) -
  • 郊区41号(许洛竹王云云)完整版免费阅读_最新全本小说郊区41号(许洛竹王云云) -
  • 负我情深几许(白诗茵陆司宴)完结版小说阅读_最热门小说排行榜负我情深几许白诗茵陆司宴 -
  • 九胞胎孕妇赖上我萱萱蓉蓉免费阅读全文_免费小说在线看九胞胎孕妇赖上我萱萱蓉蓉 -
  • 为保白月光,侯爷拿我抵了债(谢景安花田)小说完结版_完结版小说全文免费阅读为保白月光,侯爷拿我抵了债谢景安花田 -
  • 陆望程映川上官硕《我的阿爹是带攻略系统的替身》最新章节阅读_(我的阿爹是带攻略系统的替身)全章节免费在线阅读陆望程映川上官硕
  • 郑雅琴魏旭明免费阅读_郑雅琴魏旭明小说全文阅读笔趣阁
  • 头条热门小说《乔书意贺宴临(乔书意贺宴临)》乔书意贺宴临(全集完整小说大结局)全文阅读笔趣阁
  • 完结好看小说跨年夜,老婆初恋送儿子故意出车祸_沈月柔林瀚枫完结的小说免费阅读推荐
  • 热推《郑雅琴魏旭明》郑雅琴魏旭明~小说全文阅读~完本【已完结】笔趣阁
  • 《你的遗憾与我无关》宋怀川冯洛洛无弹窗小说免费阅读_免费小说大全《你的遗憾与我无关》宋怀川冯洛洛 -

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1