首先,需要大家明白一点,对于多服务器就不能用导出文件用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模板文件,应用于负载均衡多个服务器的更多相关文章

  1. Chimm.Excel —— 使用Java 操作 excel 模板文件生成 excel 文档

    Chimm.Excel -- 设置模板,填充数据,就完事儿了~ _____ _ _ _____ _ / __ \ | (_) | ___| | | | / \/ |__ _ _ __ ___ _ __ ...

  2. 使用JAVA读写Properties属性文件

     使用JAVA读写Properties属性文件 Properties属性文件在JAVA应用程序中是经常可以看得见的,也是特别重要的一类文件.它用来配置应用程序的一些信息,不过这些信息一般都是比较少的数 ...

  3. JAVA生成EXCEL模板

    JAVA生成excel模板,支持1.必填字段前加 红色 * 2.定义可选值下拉列表 valList3.定义名称并通过名称设置可选值 refName(名称在sheet2,sheet2自动隐藏)4.支持设 ...

  4. 多事之秋-最近在阿里云上遇到的问题:负载均衡失灵、服务器 CPU 100%、被 DDoS 攻击

    昨天 22:00~22:30 左右与 23:30~00:30 左右,有1台服役多年的阿里云负载均衡突然失灵,造成通过这台负载均衡访问博客站点的用户遭遇 502, 503, 504 ,由此给您带来麻烦, ...

  5. C++读写EXCEL文件OLE,java读写excel文件POI 对比

    C++读写EXCEL文件方式比较 有些朋友问代码的问题,将OLE读写的代码分享在这个地方,大家请自己看.http://www.cnblogs.com/destim/p/5476915.html C++ ...

  6. java 读写word java 动态写入 模板文件

    import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileInputStream; import ja ...

  7. java读写excel文件

    近期处理的数据规模比较大,正好又是统计合并的事情,想着借助excel就可以完成了,然后就了解了下java读取excel的事情. 读取的文件主要分两类:xls文件.xlsx文件.xls文件的相关操作用的 ...

  8. 利用java读写Excel文件

    一.读取Excel文件内容 java 代码 public static String readExcel(File file){ StringBuffer sb = new StringBuffer( ...

  9. java实现excel模板导出

    一. 准备工作 1. 点击此下载相关开发工具 2. 将poi-3.8.jxls-core-1.0两个jar包放到工程中,并引用 3. 将excel模板runRecord.xls放到RunRecordB ...

随机推荐

  1. upload-labs通关手册

    最近在练习文件上传,所以记录一下自己练习的过程,既能帮助自己以后复习,同时也能帮到初学者. 主要用到的工具是Burpsuite.首先我们应该明白上传文件的目的是什么,通过上传文件将web后门上传并被成 ...

  2. Codeforces Round #626 (Div. 2, based on Moscow Open Olympiad in Informatics)部分(A~E)题解

    (A) Even Subset Sum Problem 题解:因为n非常非常小,直接暴力枚举所有区间即可. #include<bits/stdc++.h> using namespace ...

  3. IC-二进制, 自然数, 有符号数

    https://mp.weixin.qq.com/s/9rGs9yN-OvLvEclnDZr87Q   零. 概念和结论 1. 数:概念名,指代物体的多少,即物体的量的概念: 2. 值:概念属性,数的 ...

  4. Chisel3 - util - Arbiter

    https://mp.weixin.qq.com/s/7Y23gV6yPvtmvKHTo2I8mw   基于ReadyValid接口实现的多入单出仲裁器.   参考链接: https://github ...

  5. 【asp.net core 系列】3 视图以及视图与控制器

    0.前言 在之前的几篇中,我们大概介绍了如何创建一个asp.net core mvc项目以及http请求如何被路由转交给对应的执行单元.这一篇我们将介绍一下控制器与视图直接的关系. 1. 视图 这里的 ...

  6. 【Hadoop】配置全分布式模式

    分布式原理 配置 详细过程 假设有三台虚拟机,1台master主机namenode,2台slave奴隶机datanode 所有机器都要配好jdk.Java环境变量.hadoop_env.sh里java ...

  7. js运算符和if语句,switch语句

    逻辑运算符 类型 运算符 算数运算符 +   -    *   /   %   ++   -- 赋值运算符 = 比较运算符 >   <   >=  <=   ==   !=   ...

  8. Java实现 LeetCode 762 二进制表示中质数个计算置位(位运算+JDK的方法)

    762. 二进制表示中质数个计算置位 给定两个整数 L 和 R ,找到闭区间 [L, R] 范围内,计算置位位数为质数的整数个数. (注意,计算置位代表二进制表示中1的个数.例如 21 的二进制表示 ...

  9. Java实现 蓝桥杯VIP 算法训练 蜜蜂飞舞

    时间限制:1.0s 内存限制:512.0MB 问题描述 "两只小蜜蜂呀,飞在花丛中呀--" 话说这天天上飞舞着两只蜜蜂,它们在跳一种奇怪的舞蹈.用一个空间直角坐标系来描述这个世界, ...

  10. Java实现 计蒜客 拯救行动

    拯救行动 公主被恶人抓走,被关押在牢房的某个地方.牢房用 N \times M (N, M \le 200)N×M(N,M≤200) 的矩阵来表示.矩阵中的每项可以代表道路(@).墙壁(#).和守卫( ...