poi 导出 excel 乱码问题

2018-12-04 15:11:27 +08:00
 CUMTProgrammer

response.setCharacterEncoding("utf-8"); response.setHeader("Content-disposition", "attachment;filename=" + new String(fileName.getBytes(), "utf-8")); response.setContentType("application/vnd.ms-excel");

已经按照网上的教程做了如下设置,为什么下载的 excel 还是乱码,求教。 ps:我的数据库和代码都是 utf-8 的

4077 次点击
所在节点    程序员
5 条回复
catcn
2018-12-04 15:31:28 +08:00
你直接用 save 成一个文件,然后大开看看是不是乱码啦,设置浏览器头什么的,有时候用处不大
raphael008
2018-12-04 17:27:11 +08:00
response.setContentType("application/vnd.ms-excel; charset=utf-8");
xyjincan
2018-12-05 08:35:58 +08:00
poi 是一个二进制流文件,为啥弄个 utf8 编码返回
Antihank
2018-12-05 09:26:17 +08:00
你这样可能 poi 生成的文件就是乱码的吧,改 resp 的 Header 用处不大,去你的文件服务器把生成的文件下载一下看看是不是乱码。
CUMTProgrammer
2018-12-05 09:37:12 +08:00
@catcn
@Antihank
解决了,是 swagger 的问题,用 swagger 造成的中文乱码

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/514215

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX