springboot打成Jar包下载Excel模板文件损坏问题

最近遇到Springboot环境项目打成jar后下载Excle文件出现损坏问题,我是在网上找了这种方法解决的:

String fileName = "aaa.xlsx";

ClassPathResource cpr = new ClassPathResource("/download/" + fileName);

InputStream in = cpr.getInputStream();

XSSFWorkbook workbook = new XSSFWorkbook(in);

response.setContentType("application/binary;charset=ISO8859-1");

//防止中文乱码问题

String finalFileName = "";

String userAgent = request.getHeader("USER-AGENT");

if (userAgent.contains("Firefox")) {//火狐

finalFileName = new String(fileName.getBytes("UTF-8"), "ISO-8859-1");

} else {//IE,google等其他浏览器

finalFileName = URLEncoder.encode(fileName, "UTF8");

}

response.setHeader("Content-disposition", "attachment; filename=" + finalFileName);

ServletOutputStream out = response.getOutputStream();

workbook.write(out);

out.flush();

out.close();

要说明的是如果你是在Eclipse上或者IDEA上跑项目时下载就损坏,那你要看下pom中对resouces的权限配置,如果你在开发工具环境下下载没问题,在jar包环境有问题,可以用我以上代码试试,我的是这么解决的.

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值