// 生成excel
File outFile = new File(exportFileSavePath + File.separator + excelFileName);
try {
// 设置response的编码方式
request.setCharacterEncoding("UTF-8");
response.setContentType("application/msexcel");
// 设置附加文件名
response.setHeader("Content-Disposition",
"attachment;filename=" + URLEncoder.encode(excelFileName, StandardCharsets.UTF_8.name()));
} catch (Exception e) {
logger.error("Excel导出编码异常:" + e);
}
// 读出文件到i/o流
try (BufferedInputStream buff = new BufferedInputStream(new FileInputStream(outFile));
OutputStream os = response.getOutputStream()) {
byte[] b = new byte[1024];// 相当于我们的缓存
long k = 0;// 该值用于计算当前实际下载了多少字节
// 从response对象中得到输出流,准备下载
// 开始循环下载
while (k < outFile.length()) {
int j = buff.read(b, 0, 1024);
k += j;
// 将b中的数据写到客户端的内存
os.write(b, 0, j);
}
// 将写入到客户端的内存的数据,刷新到磁盘
os.flush();
} catch (Exception e) {
logger.error(e.toString());
}
File outFile = new File(exportFileSavePath + File.separator + excelFileName);
try {
// 设置response的编码方式
request.setCharacterEncoding("UTF-8");
response.setContentType("application/msexcel");
// 设置附加文件名
response.setHeader("Content-Disposition",
"attachment;filename=" + URLEncoder.encode(excelFileName, StandardCharsets.UTF_8.name()));
} catch (Exception e) {
logger.error("Excel导出编码异常:" + e);
}
// 读出文件到i/o流
try (BufferedInputStream buff = new BufferedInputStream(new FileInputStream(outFile));
OutputStream os = response.getOutputStream()) {
byte[] b = new byte[1024];// 相当于我们的缓存
long k = 0;// 该值用于计算当前实际下载了多少字节
// 从response对象中得到输出流,准备下载
// 开始循环下载
while (k < outFile.length()) {
int j = buff.read(b, 0, 1024);
k += j;
// 将b中的数据写到客户端的内存
os.write(b, 0, j);
}
// 将写入到客户端的内存的数据,刷新到磁盘
os.flush();
} catch (Exception e) {
logger.error(e.toString());
}
45万+

被折叠的 条评论
为什么被折叠?



