java读写Excel模板文件,应用于负载均衡多个服务器
首先,需要大家明白一点,对于多服务器就不能用导出文件用a标签访问链接方式去导出excel文件了,原因相信大家也明白,可能也做过尝试。
现在开始第一步:get请求,productPath 为你的项目路径
var url=productPath + "/CtrlService"+"?action=ZcjqrGlfExport&UserName="+ username+"&FILENAME="+ filePath;
window.open(url);
第二步:
public Object doCtrlService(StubObject arg0, JParamObject arg1, HttpServletRequest req,
HttpServletResponse resp)
throws Exception {
String filePath = req.getParameter("FILENAME");
try {
JParamObject PO=JParamObject.getInstance();
PO.SetValueByParamName("filePath", filePath);
PO.setEnvValue("DBNO", "FMIS_DB01");
PO.setEnvValue("DataBaseName", "FMIS_DB01");
JResponseObject RO=(JResponseObject) EAI.DAL.SVR("FMIS_ZCJQR_GLFFT_EXPORT", PO);
String fileName=(String)RO.getResponseObject("fileName");
byte[] fileBytes=(byte[])RO.getResponseObject("fileBytes");
if(fileBytes==null){
return null;
}
setResponseHeader(resp,fileName,".xls");
ServletOutputStream out=resp.getOutputStream();
try{
out.write(fileBytes);
out.close();
}catch(Exception e){
if(e.getClass().getName().equals("org.apache.catalina.connector.ClientAbortException")){
logger.info("客户端终止操作");
return null;
}
throw e;
}
} catch (Exception e) {
String errMsg = "异常";
logger.error(errMsg,e);
ServiceException se = new ServiceException(e.getMessage());
se.setErrorCode(-502);
se.setErrorMessage(errMsg);
throw se;
}
return null;
} private void onError(HttpServletResponse resp, String msg) throws Exception {
resp.setHeader("Content-type", "text/html;charset=UTF-8");
resp.setCharacterEncoding("UTF-8");
resp.getWriter().print(msg);
} private void setResponseHeader(HttpServletResponse resp, String fileName, String fileType) throws Exception { String fileNameEncode = java.net.URLEncoder.encode(fileName, "UTF-8");
String[][] contentType =
{
{".xls","application/x-xls"}
};
for (int i = 0; i < contentType.length; i++) {
if (contentType[i][0].equals(fileType)) {
resp.setContentType(contentType[i][1]);
break;
}
}
resp.addHeader("Content-Disposition", "attachment;filename=" + fileNameEncode);
return; }
第三步:读取模板文件,并输出文件流
private byte[] fileExport(JConnection conn, JParamObject PO) {
InputStream io;
String path=EAI.LocalUserHome;
String modelfilepath=path+"importTemp"+File.separator+"Glfftmodel.xls";
String filename=TempleNameUtils.createTempTableName("glfmx_");
String outputPath=path+"exporttemp"+File.separator+filename+".xls";
ByteArrayOutputStream outputStream = null;
byte[] bytes = new byte[0];
deleteExcelBeforeExport(path+"exporttemp","glfmx");
try{
//这里读出来的workbook作为模版
io = new FileInputStream(new File(modelfilepath));
HSSFWorkbook workbook = new HSSFWorkbook(io);
HSSFSheet sheet=workbook.getSheetAt(0);
List<Glfftbean> listg=QueryGlfftList(conn);
HSSFCellStyle cellStyle = workbook.createCellStyle(); // 单元格样式
cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
for(int i=0;i<listg.size();i++){
Glfftbean glfftbean=listg.get(i);
System.out.println(i);
String xmbh= glfftbean.getXmbh();
HSSFRow row=sheet.getRow(i+9);//第10行开始
if (row == null) {
row = sheet.createRow(i+9);
row.createCell(0).setCellValue(xmbh);
row.createCell(1).setCellValue(glfftbean.getXmmc());
row.createCell(2).setCellValue(glfftbean.getQmzjgc());
row.createCell(3).setCellValue(glfftbean.getZcbh());
row.createCell(4).setCellValue(glfftbean.getZcmc());
row.createCell(5).setCellValue(glfftbean.getCbzxbh());
row.createCell(6).setCellValue(glfftbean.getCbzxmc());
row.createCell(7).setCellValue(glfftbean.getFtje());
row.createCell(8).setCellValue(glfftbean.getQzfzcbh());
}else{
row.getCell(0).setCellValue(xmbh);
row.getCell(1).setCellValue(glfftbean.getXmmc());
row.getCell(2).setCellValue(glfftbean.getQmzjgc());
row.getCell(3).setCellValue(glfftbean.getZcbh());
row.getCell(4).setCellValue(glfftbean.getZcmc());
row.getCell(5).setCellValue(glfftbean.getCbzxbh());
row.getCell(6).setCellValue(glfftbean.getCbzxmc());
row.getCell(7).setCellValue(glfftbean.getFtje());
row.getCell(8).setCellValue(glfftbean.getQzfzcbh());
}
for (Cell cell : row) {
cell.setCellStyle(cellStyle);
}
}
File file= new File(outputPath);
FileOutputStream fo=new FileOutputStream(file);
workbook.write(fo);
workbook.close();
long fileSize = file.length();
FileInputStream in = new FileInputStream(file);
byte[] buffer = new byte[(int) fileSize];
while ((fileSize = in.read(buffer)) != -1) {
return buffer;
}
in.close();
return buffer;
}catch (Exception e){
String errMsg = "创建文件流失败";
logger.error(errMsg, e);
ServiceException se = new ServiceException(e.getMessage());
se.setErrorCode(-1);
se.setErrorMessage(errMsg);
}
return bytes;
}
删除相关文件:
public static void deleteExcelBeforeExport(String path, String username) {
File file = new File(path);
File[] fileList = file.listFiles();
if (fileList != null) {
for (int i = 0; i < fileList.length; i++) {
File fs = fileList[i];
if (!fs.isDirectory()) {
String[] fileNames = fs.getName().split("_");
if (fileNames.length > 1) {
String fileUserName = fileNames[0];
// --删除包含该用户名的并且后缀的开头为
if (fileUserName.equals(username)) {
String deleteFilePath = path + File.separator + fs.getName();
File deleteFile = new File(deleteFilePath);
deleteFile.delete();
}
}
}
}
}
}
结束
思路总结:需要生成文件 ->读取文件 -> 输出文件流 -> 删除文件
属作者原创,如有转载,请表明出处:https://www.cnblogs.com/mobeisanghai/p/12191374.html
java读写Excel模板文件,应用于负载均衡多个服务器的更多相关文章
- Chimm.Excel —— 使用Java 操作 excel 模板文件生成 excel 文档
Chimm.Excel -- 设置模板,填充数据,就完事儿了~ _____ _ _ _____ _ / __ \ | (_) | ___| | | | / \/ |__ _ _ __ ___ _ __ ...
- 使用JAVA读写Properties属性文件
使用JAVA读写Properties属性文件 Properties属性文件在JAVA应用程序中是经常可以看得见的,也是特别重要的一类文件.它用来配置应用程序的一些信息,不过这些信息一般都是比较少的数 ...
- JAVA生成EXCEL模板
JAVA生成excel模板,支持1.必填字段前加 红色 * 2.定义可选值下拉列表 valList3.定义名称并通过名称设置可选值 refName(名称在sheet2,sheet2自动隐藏)4.支持设 ...
- 多事之秋-最近在阿里云上遇到的问题:负载均衡失灵、服务器 CPU 100%、被 DDoS 攻击
昨天 22:00~22:30 左右与 23:30~00:30 左右,有1台服役多年的阿里云负载均衡突然失灵,造成通过这台负载均衡访问博客站点的用户遭遇 502, 503, 504 ,由此给您带来麻烦, ...
- C++读写EXCEL文件OLE,java读写excel文件POI 对比
C++读写EXCEL文件方式比较 有些朋友问代码的问题,将OLE读写的代码分享在这个地方,大家请自己看.http://www.cnblogs.com/destim/p/5476915.html C++ ...
- java 读写word java 动态写入 模板文件
import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import ja ...
- java读写excel文件
近期处理的数据规模比较大,正好又是统计合并的事情,想着借助excel就可以完成了,然后就了解了下java读取excel的事情. 读取的文件主要分两类:xls文件.xlsx文件.xls文件的相关操作用的 ...
- 利用java读写Excel文件
一.读取Excel文件内容 java 代码 public static String readExcel(File file){ StringBuffer sb = new StringBuffer( ...
- java实现excel模板导出
一. 准备工作 1. 点击此下载相关开发工具 2. 将poi-3.8.jxls-core-1.0两个jar包放到工程中,并引用 3. 将excel模板runRecord.xls放到RunRecordB ...
随机推荐
- java方式实现基数排序
一.基数排序描述 基数排序(radix sort)属于"分配式排序"(distribution sort),又称"桶子法"(bucket sort)或bin s ...
- Beta冲刺——测试随笔
这个作业属于哪个课程 软件工程 这个作业要求在哪里 团队作业第五次--Beta冲刺 这个作业的目标 Beta冲刺 作业正文 正文 github链接 项目地址 其他参考文献 无 一.测试工作安排 项目 ...
- Java 第十一届 蓝桥杯 省模拟赛 螺旋矩阵
螺旋矩阵 题目 问题描述 对于一个 n 行 m 列的表格,我们可以使用螺旋的方式给表格依次填上正整数,我们称填好的表格为一个螺旋矩阵. 例如,一个 4 行 5 列的螺旋矩阵如下: 1 2 3 4 5 ...
- Java实现 LeetCode 887 鸡蛋掉落(动态规划,谷歌面试题,蓝桥杯真题)
887. 鸡蛋掉落 你将获得 K 个鸡蛋,并可以使用一栋从 1 到 N 共有 N 层楼的建筑. 每个蛋的功能都是一样的,如果一个蛋碎了,你就不能再把它掉下去. 你知道存在楼层 F ,满足 0 < ...
- Java实现LeetCode 139 单词拆分
public boolean wordBreak(String s, List<String> wordDict) { if(s.length() == 0){ return false; ...
- Java实现 洛谷 P1089 津津的储蓄计划
import java.util.*; public class Main { public static void main(String[] args) { Scanner sc=new Scan ...
- java实现排他平方数
题目标题: 排它平方数 小明正看着 203879 这个数字发呆. 原来,203879 * 203879 = 41566646641 这有什么神奇呢?仔细观察,203879 是个6位数,并且它的每个数位 ...
- java实现第六届蓝桥杯加法变乘法
加法变乘法 题目描述 我们都知道:1+2+3+ - + 49 = 1225 现在要求你把其中两个不相邻的加号变成乘号,使得结果为2015 比如: 1+2+3+-+1011+12+-+2728+29+- ...
- 下拉式菜单中的内容堆叠(ul型)
今天使用ul创建下拉式菜单,菜单中的内容堆在了一起. 这是我的html代码 <!DOCTYPE html> <html lang="en"> <hea ...
- 两条命令实现nodejs快速安装
操作系统: debian, ubuntu, fedora 当前版本: v14.4.0 一键安装命令: curl -sL https://deb.nodesource.com/setup_14.x | ...