java写入excel乱码_Java导出Excel解决乱码及导出文件打开不可读需修复的问题

导入包,本来自己也不想用poi处理的,怎奈不知道为什么自己用流导出总是会报错不可读,所以还是简单点吧:

org.apache.poi

poi-ooxml

3.9

工具代码:

public class FileUtil {

public static void download(String filename, HttpServletResponse res) {

String filePath = "./template/" + filename;

try (OutputStream os = res.getOutputStream(); InputStream bis = new BufferedInputStream(new ClassPathResource(filePath).getInputStream())){

// 设置信息给客户端不解析

String type = new MimetypesFileTypeMap().getContentType(filename);

// 设置content-type,即告诉客户端所发送的数据属于什么类型

res.setContentType(type);

// 设置编码

String name = URLEncoder.encode(filename, "UTF-8");

// 设置扩展头,当Content-Type 的类型为要下载的类型时 , 这个信息头会告诉浏览器这个文件的名字和类型。

res.setHeader("Content-Disposition", "attachment;filename=" + name);

XSSFWorkbook workbook = new XSSFWorkbook(bis);

workbook.write(os);

}catch (Exception e){

e.printStackTrace();

}

}

}

重点是这句:XSSFWorkbook workbook = new XSSFWorkbook(bis);

文件所在位置:

65cb7b2d39c12ad9a55c69e2987e8cd0.png

标签:Java,String,res,导出,filename,乱码,new,XSSFWorkbook,bis

来源: https://blog.csdn.net/seanxwq/article/details/104774543

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值