xlsx文件下载异常问题

前端调用我的后端接口下载xlsx文件,里面的数据没有正常展示。如下所示:

查看前端响应头里面。多了个charset=utf-8;

java 复制代码
application/octet-stream;charset=utf-8

如果是下面这种响应不会有问题,但是上面二进制流有charset=utf-8,浏览器会把这个当文本处理,不会解析成文件。

改动之前下载接口如下:

java 复制代码
  @ApiOperation(value = "oss文件下载")
    @GetMapping("downOssFile")
    public ResponseEntity<byte[]> getFileByUrl(String url, String fileName) {
        byte[] body = ossManager.download(url);
        HttpHeaders headers = new HttpHeaders();

        headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
        try {
            String encodeFileName = URLEncoder.encode(fileName, "utf-8").replaceAll("\\+", "%20");
            headers.set("Content-Disposition", "attachment;filename=" + encodeFileName);
        } catch (UnsupportedEncodingException e) {
            log.error("oss文件下载失败,e:", e);
            throw new RuntimeException(e);
        }
        ResponseEntity<byte[]> result = ResponseEntity.ok().headers(headers).body(body);
        return result;
    }

这个接口返回体是使用Spring的ResponseEntity<byte\[\]> , Spring 的 ByteArrayHttpMessageConverter 会序列化处理该响应体。 最后过滤器在 response 提交后仍可修改 header。

检查我的web.xml文件配置是这样的,强制在所有接口的请求的响应头里面加上charset=UTF-8设置。这是问题的根源所在。

java 复制代码
    <filter>
		<filter-name>ProjectEncoding</filter-name>
		<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
		<async-supported>true</async-supported>
		<init-param>
			<param-name>encoding</param-name>
			<param-value>UTF-8</param-value>
		</init-param>
		<init-param>
			<param-name>forceEncoding</param-name>
			<param-value>true</param-value>
		</init-param>
	</filter>
	<filter-mapping>
		<filter-name>ProjectEncoding</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>

下面是我修改之后的下载接口:

java 复制代码
@ApiOperation(value = "oss文件下载")
    @GetMapping("downOssFile")
    public void getFileByUrl(String url, String fileName, HttpServletResponse response) throws IOException {
        byte[] body = ossManager.download(url);
        response.setHeader("Content-Type", "application/octet-stream");
        String encodeFileName = URLEncoder.encode(fileName, "utf-8").replaceAll("\\+", "%20");
        response.setHeader("Content-Disposition", "attachment;filename=" + encodeFileName);
        response.getOutputStream().write(body);
    }

使用原生的Response方法,绕过过滤器,getOutputStream().write() 会提前提交 response,过滤器无法再改charset。这样xlsx文件才能正常解析。

这个问题确实也排查了好久,总结来说对于上传以及下载文件异常问题首先考虑的就是响应头或者请求头,一般问题都出在这两个。

相关推荐
程序大视界6 分钟前
【C++ 从基础到项目实战】C++(六):拷贝控制——浅拷贝与深拷贝,兼谈智能指针
开发语言·c++·cpp
luck_bor8 分钟前
IO流知识点笔记
java·开发语言·笔记
程序大视界13 分钟前
【Python系列课程】Pandas(四):数据统计与排序——describe、sort_values、sample
开发语言·python·pandas
KWTXX31 分钟前
使用matlab官网的skills调用claude-待完成
开发语言·matlab
Cthy_hy1 小时前
Python算法竞赛:排列组合核心用法
开发语言·python·算法
大圣编程1 小时前
面向对象深度理解
java·开发语言·算法
爱喝水的鱼丶1 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
影寂ldy1 小时前
C# const 常量 / readonly 只读 / static readonly
java·开发语言·c#
摇滚侠1 小时前
Maven 入门+高深 体系外 jar 包导入 172
java·maven·jar