springboot实现excel文件下载的功能

本文介绍了一种在SpringBoot项目中实现Excel模板下载的方法,通过ClassPathResource获取资源文件,利用HttpServletResponse设置响应头实现文件的下载,适用于数据导入导出场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

场景:由于需要使用poi进行数据的导入和导出,在导入的时候excel的格式是很严格的,所以我们需要提供一个excel模板让运维人员添加数据然后再上传,这样格式就不会有问题了,虽然功能简单,但是copy了很多代码都是有问题的,最后好不容易找到个可以用的,分享一下

实现方法:

1.文件位置位于resoures文件夹下


2.源码

@RequestMapping("/download")
    public void downloadFile(HttpServletResponse response) throws IOException {
		 try {
			 	Resource resource = new ClassPathResource("poi/运费模板.xlsx");
	    		File file = resource.getFile();
	    		String filename = resource.getFilename();
	    		InputStream inputStream = new FileInputStream(file);
                //强制下载不打开
	    		response.setContentType("application/force-download");
	            OutputStream out = response.getOutputStream();
                //使用URLEncoder来防止文件名乱码或者读取错误
	            response.setHeader("Content-Disposition", "attachment; filename="+URLEncoder.encode(filename, "UTF-8"));
	            int b = 0;
	            byte[] buffer = new byte[1000000];
	            while (b != -1) {
	                b = inputStream.read(buffer);
	                if(b!=-1) out.write(buffer, 0, b);
	            }
	            inputStream.close();
	            out.close();
	            out.flush();
	        } catch (IOException e) {
	            e.printStackTrace();
	        }
    }

说明:springboot中可以使用ClassPathResource类来直接获取resources中的文件

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

巴中第一皇子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值