java从项目里下载excel模板

从本地项目中下载excel模版

    @RequestMapping(value = "/downloadExcelByName", method = RequestMethod.GET)
public void downloadExcelByName(String fileName, HttpServletRequest request, HttpServletResponse response)
		throws Exception {
	OutputStream os = null;
	try {
		// 文件下载
		//response.setContentType("multipart/form-data");
		response.setContentType("application/vnd.ms-excel;charset=UTF-8");
		response.setHeader("Content-Disposition",
				"attachment;filename=" + StringUtilx.encodeFileName(request, fileName));
		 os = response.getOutputStream();
		 InputStream bis = null;
		 bis = this.getClass().getResourceAsStream("/"+fileName);//获取项目中文件的流
		 ByteArrayOutputStream swapStream = new ByteArrayOutputStream(); 
		 byte[] buff = new byte[100]; //buff用于存放循环读取的临时数据 
		 int rc = 0; 
		 while ((rc = bis.read(buff, 0, 100)) > 0) { 
		 swapStream.write(buff, 0, rc); //写入到字节数组输出流中
		 } 
		 byte[] excelByteFile = swapStream.toByteArray();//将字节流转化成字节数组,直接输出会有丢失。
		 int i = 0;
			while ((i + 1024) <= excelByteFile.length) {
				os.write(excelByteFile, i, 1024);
				i += 1024;
			}
			int len = excelByteFile.length % 1024;
			if (len > 0) {
				os.write(excelByteFile, i, len);
			}
	} catch (IOException e) {
		e.printStackTrace();
	} finally {
		os.close();
	}
}

如果下载下来的打不开,可能是由于maven进行了统一编码在maven 加入以下插件 clean以下在启动

org.apache.maven.plugins
2.6
maven-resources-plugin

UTF-8

xlsx


第二种

public class FileUtil {

    private final static Logger log = LoggerFactory.getLogger(FileUtil.class);

    /**
     * 下载项目根目录下doc下的文件
     *
     * @param response response
     * @param fileName 文件名
     * @return 返回结果 成功或者文件不存在
     */
    public static Response downloadFile(HttpServletResponse response, String fileName) {
        InputStream stream = FileUtil.class.getClassLoader().getResourceAsStream("static/excel/" + fileName);
        if (stream == null) {
            log.error("文件没有找到");
            throw new RuntimeException("没有找到文件");
        }
        response.setHeader("content-type", "application/octet-stream");
        response.setContentType("application/vnd.ms-excel;charset=utf-8");
        try {
            String name = java.net.URLEncoder.encode(fileName, "UTF-8");
            response.setHeader("Content-Disposition", "attachment;filename=" + java.net.URLDecoder.decode(name, "ISO-8859-1"));
        } catch (UnsupportedEncodingException e) {
            log.error("文件名转换编码出现问题:" + e.getMessage());
        }
        byte[] buff = new byte[1024];
        BufferedInputStream bis = null;
        OutputStream os = null;
        try {
            os = response.getOutputStream();
            bis = new BufferedInputStream(stream);
            int i = bis.read(buff);
            while (i != -1) {
                os.write(buff, 0, buff.length);
                os.flush();
                i = bis.read(buff);
            }
        } catch (FileNotFoundException e) {
            e.printStackTrace();
            log.error("系统找不到指定的文件:" + e.getMessage());
            return Response.error("系统找不到指定的文件");
        } catch (IOException e) {
            e.printStackTrace();
            log.error("Io流写入出现错误:" + e.getMessage());
            return Response.error("Io流写入出现错误");
        } finally {
            try {
                os.close();
                if (bis != null) {
                    bis.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
                log.error("关闭流出现错误:" + e.getMessage());
                return Response.error("关闭流出现错误");
            }
        }
        return Response.success();
    }```

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值