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 ...
随机推荐
- string 去重复
//AABB>>AB //AAA>>A //ABBAA>ABA public static string SpiltString(stri ...
- 【Python】基础总结
输入 input("提示性信息") 如: input("请输入数字") 评估函数 因为 Python 没有特别人为规定数据类型,数据类型是由计算机进行判定,所以 ...
- 01 . Squid原理配置和使用
Squid简介 Squid是一个支持HTTP,HTTPS,FTP等服务的Web缓存代理软件,它可以通过缓存页面来提高服务器的相应速度并降低带宽占用.并且,Squid还具有强大的访问控制功能.Squid ...
- seo网站优化收录过少的病因分析-智狐seo顾问
seo网站优化收录过少的病因分析 很多网站优化人员都了解,一个网站收录的重要性,企业网站要想可以在百度中占据一个良好的排名,获取的权重更高,那么网站收录自然就上去了,很多站长们在操作的过程中就会出现不 ...
- 1. vue文件结构
1)这是文件规则 <template> <div > </div> </template> <script> Name:"当前的名 ...
- Chisel3 - 参考资料汇总
https://mp.weixin.qq.com/s/mIexKCFA1MQNOl4M_iVkjg 1. 官方网站 https://chisel.eecs.berkeley.edu/ ...
- Java实现 LeetCode 566 重塑矩阵(遍历矩阵)
566. 重塑矩阵 在MATLAB中,有一个非常有用的函数 reshape,它可以将一个矩阵重塑为另一个大小不同的新矩阵,但保留其原始数据. 给出一个由二维数组表示的矩阵,以及两个正整数r和c,分别表 ...
- Java实现 蓝桥杯VIP 算法训练 整数平均值
题目描述 编写函数,求包含n个元素的整数数组中元素的平均值.要求在函数内部使用指针操纵数组元素,其中n个整数从键盘输入,输出为其平均值. (样例说明:5为输入数据的个数,3 4 0 0 2 是以空格隔 ...
- Java实现 LeetCode 227 基本计算器 II(二)
227. 基本计算器 II 实现一个基本的计算器来计算一个简单的字符串表达式的值. 字符串表达式仅包含非负整数,+, - ,*,/ 四种运算符和空格 . 整数除法仅保留整数部分. 示例 1: 输入: ...
- Java实现 蓝桥杯 算法提高 宰羊
试题 算法提高 宰羊 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 炫炫回了内蒙,肯定要吃羊肉啦,所有他家要宰羊吃. 炫炫家有N只羊,羊圈排成一排,标号1~N.炫炫每天吃掉一只羊( ...