vue+springboot下载文件名称乱码

一、先说症状:

下载文件内容没有乱码,但是文件名乱码,且捕获的请求,响应头携带的也没有乱码,只有在vue中获取的名称乱码:如下图:
在这里插入图片描述

二、解决问题

1、错误思路:

一开始走了很多弯路,一直在修改后端代码,尝试了多种字符编码方式,如下:
第一种:

response.setHeader("Content-Disposition", "attachment;filename=" + new String(fileName.getBytes("UTF-8"),"ISO-8859-1"));

第二种:

response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName,"UTF-8"));

尝试过之后前端获取仍然是乱码。(浏览器兼容问题自行解决)

2、解决

后来发现,仅仅修改后端代码是不行的,要前后端一起修改。
后端代码如下:

response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName,"UTF-8"));

前端代码如下:

 let contentDisposition = response.headers['content-disposition'];
 // fileName必用这种方式进行解析,否则乱码
 let fileName = window.decodeURI(contentDisposition.substring(contentDisposition.indexOf('=')+1));
 console.log('fileName=' + fileName);
 let url = window.URL.createObjectURL(new Blob([data]));
 let a = document.createElement('a');
 a.style.display = 'none';
 a.href = url;
 a.setAttribute('download',fileName);
 document.body.appendChild(a);
 //点击下载
 a.click();
 // 下载完成移除元素
 document.body.removeChild(a);
 // 释放掉blob对象
 window.URL.revokeObjectURL(url);
 console.log("下载完成");

注意,后端代码只能使用URLEncoder.encode来转编码(不能使用String来进行转编码),前端配合使用window.decodeURI来解码,任何一个不匹配都会造成乱码。

修改后效果如下:
在这里插入图片描述

  • 12
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Vue和Spring Boot中实现文件下载的方法有多种。根据提供的引用内容,我们可以使用文件流的方式来实现。首先,在Vue的前端代码中需要定义一个下载文件的方法,可以通过点击按钮触发该方法。 在Vue的前端代码中,我们可以使用Element UI等前端框架来创建一个按钮,绑定一个click事件方法,例如: ```html <template> <div> <el-button size="medium" type="success" plain @click="downLoadFile">下载</el-button> </div> </template> ``` 接着,在Vue的JavaScript逻辑部分,使用axios调用后端接口来进行文件的下载。具体的JavaScript代码如下所示: ```javascript export default { name: "xxx", data() { return { filePath: 'D:\file\文件名称.pdf', // 文件路径 fileName: '文件名称.pdf', // 文件名称 } }, methods: { // 下载文件方法 downLoadFile() { this.$axios.get("/downFile/downLoadFile", { params: { path: this.filePath, name: this.fileName }, responseType: 'blob' }).then(res => { const blob = new Blob([res.data]); const fileName = res.headers["content-disposition"].split(";")[1].split("filename=")[1]; if ('download' in document.createElement("a")) { const link = document.createElement("a"); link.download = fileName; link.style.display = 'none'; link.href = URL.createObjectURL(blob); document.body.appendChild(link); link.click(); URL.revokeObjectURL(link.href); document.body.removeChild(link); } else { navigator.msSaveBlob(blob, fileName); } }) } }, } ``` 在上述代码中,我们通过axios发送GET请求到后端接口`"/downFile/downLoadFile"`,并传递文件的路径和名称作为请求参数。同时,我们指定了`responseType`为`blob`,以便获取到文件的二进制数据。在获取到文件数据后,我们将其保存为Blob对象,并使用创建的下载链接进行文件的下载。 请注意,以上代码仅为示例,实际的路径和文件名需要根据具体情况进行修改。此外,需要确保后端接口正确处理文件下载请求,并返回文件的二进制数据。 综上所述,以上代码演示了在Vue和Spring Boot中实现文件下载的方法,你可以根据需要进行调整和扩展。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span> #### 引用[.reference_title] - *1* *2* *3* *4* [vue+springboot使用文件流实现文件下载](https://blog.csdn.net/xc9711/article/details/127485603)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值