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文件才能正常解析。

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

相关推荐
secret_to_me2 小时前
裴行俭VS袁天罡和李淳风
开发语言
ATCH IERV2 小时前
Redis6.2.6下载和安装
java
2601_953465612 小时前
M3U8 在线播放器:无需安装,一键调试 HLS 直播流
开发语言·前端·javascript·开发工具·m3u8·m3u8在线播放
wechatbot8882 小时前
企业微信全场景消息发送接口开发实现及接口调用
java·汇编·微信·企业微信
2501_913061342 小时前
网络原理之HTTP(3)
java·网络·网络协议·http·面试
郭涤生2 小时前
C++ 线程同步复习
开发语言·c++
Mem0rin2 小时前
[Java]排序
java·算法·排序算法
Full Stack Developme2 小时前
Hutool EnumUtil 教程
开发语言·windows·python
番茄去哪了2 小时前
JeecgBoot框架集成spring ai并进行同步调用异步调用模板
java·人工智能·spring