java、jsp导出excel功能备份
问题踩坑:
ajax请求不能下载文件
必须这样:
<a href="/media">点击下载Excel</a>
或者
location.href = '/media';
js取表单数据:
var selectbatch = $("selectbatch").value
java代码:
package com.action;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.log4j.Logger;
import com.IHttpAction;
import com.sql.ExchangeSql;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.NumberFormats;
import jxl.write.WritableCell;
import jxl.write.WritableCellFormat;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
/**
* @FileName: ExchangeSelectAction.java
* @Description:
* @Author : xingchong
* @CreateTime: Nov 15, 2018 8:42:45 PM
* @Copyright: Copyright (c) 2017
* @Version: 1.0
*/
public class ExchangeExportAction implements IHttpAction {
private ExchangeSql exchangeSql = new ExchangeSql();
private Logger logger = Logger.getLogger(ExchangeExportAction.class);
/* (non-Javadoc)
* @see com.gm.console.IHttpAction#action(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse)
*/
@Override
public void action(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
int batch = Integer.parseInt(request.getParameter("selectbatch"));
logger.info("selectbatch = "+ batch);
try {
InputStream is = this.exportExchangeCode(batch);
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd_HH-mm-ss");
String fileName = "batch_"+batch+"_"+sdf.format(new Date()) + ".xls";
response.setContentType("applicaiton/x-download");
response.addHeader("Content-Disposition", "attachment;filename="+fileName);
ServletOutputStream out=response.getOutputStream();
int len=0;
byte[] buffer=new byte[1024];
while((len=is.read(buffer))>0){
out.write(buffer,0,len);
}
is.close();
out.close();
// response.getWriter().write("<span>export excel ok...</span>");
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 获取兑换码html信息
*
* @param batch
* @return
* @throws Exception
*/
private InputStream exportExchangeCode(int batch) throws Exception {
List<List<String>> dataList = null;
if (batch > 0) {
dataList = this.exchangeSql.getExchangeData(batch, Integer.MAX_VALUE);
} else {
dataList = this.exchangeSql.getSimpleExchangeData(Integer.MAX_VALUE);
}
List<String> titleList = dataList.get(0);
dataList.remove(0);
InputStream is = null;
try {
ByteArrayOutputStream os = new ByteArrayOutputStream();
WritableWorkbook wwb = Workbook.createWorkbook(os);
int step = 50000;
int size = dataList.size();
int sheetIndex = 0;
for(int start = 0; start < size; start+=step){
int end = start + step;
end = end > size? size:end;
List<List<String>> dataListSub = new ArrayList<List<String>>();
dataListSub.add(titleList);
dataListSub.addAll(dataList.subList(start, end));
this.writeDataToSheet(wwb, dataListSub, sheetIndex++);
}
wwb.write();
wwb.close();
is = new ByteArrayInputStream(os.toByteArray());
} catch (IOException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
return is;
}
/**
* 写一页excel
* @param wwb
* @param dataList
* @param sheetIndex
* @throws RowsExceededException
* @throws WriteException
*/
private void writeDataToSheet(WritableWorkbook wwb, List<List<String>> dataList, int sheetIndex)
throws RowsExceededException, WriteException {
WritableSheet sheet = wwb.createSheet("data_"+sheetIndex, sheetIndex);
WritableCellFormat wcf = new WritableCellFormat(NumberFormats.TEXT);
for (int r = 0; r < dataList.size(); r++) {
List<String> list = dataList.get(r);
for (int c = 0; c < list.size(); c++) {
String string = list.get(c);
WritableCell writableCell = new Label(c, r, string, wcf);
sheet.addCell(writableCell);
}
}
}
}
jsp代码:
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core_rt"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<title>My JSP 'buildinglist.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="Content-type" content="text/html charset=utf-8">
<meta http-equiv="expires" content="0">
<LINK href="/console/style/default.css" type=text/css rel=stylesheet>
<LINK href="/console/style/style.css" type=text/css rel=stylesheet>
<LINK href="/console/style/style3.css" type=text/css rel=stylesheet>
<LINK href="/console/style/tab.webfx.css" type=text/css rel=StyleSheet>
<link href="/console/style/calendar.css" type=text/css rel=StyleSheet>
<script type="text/javascript" src="/console/js/prototype.js"></script>
<script type="text/javascript" src="/console/js/tools.js"></script>
<script type="text/javascript" src="/console/js/calendar.js"
charset="utf-8"></script>
<script type="text/javascript" src="/console/js/swfobject.js"
charset="utf-8"></script>
<script type="text/javascript">
function btnAjax() {
$("resultTable").innerHTML = "<span style=\"color: red;\">正在紧张生成中...请勿重复点击...</span>";
var myAjax = new Ajax.Request("customRequest.htm?catalog=exchange_add",
{
method : 'post',
parameters : Form.serialize('Form1'),
onComplete : function(x) { //提交成功回调
$("resultTable").innerHTML = x.responseText;
},
onError : function(x) { //提交失败回调
alert(x.statusText);
}
});
}
function selectAjax() {
$("selectTable").innerHTML = "<span style=\"color: green;\">正在查询中...请稍等...</span>";
var myAjax = new Ajax.Request(
"customRequest.htm?catalog=exchange_select", {
method : 'post',
parameters : Form.serialize('Form1'),
onComplete : function(x) { //提交成功回调
$("selectTable").innerHTML = x.responseText;
},
onError : function(x) { //提交失败回调
alert(x.statusText);
}
});
}
//export excel
function exportExcel() {
var selectbatch = $("selectbatch").value
location.href = '/customRequest.htm?catalog=exchange_export&selectbatch='+selectbatch;
}
</script>
<style type="text/css">
</style>
</HEAD>
<body>
<form id="Form1" name="Form1" method="post">
<div style="clear: both; height: 1px; overflow: hidden"></div>
<div width="98%" align="left" valign="left">
<font size="6px"> <br>兑换码生成 <br>
<br>
</font> ${result}
</div>
<table align="left" class=detail>
<tbody>
<tr>
<td class="list_td01">类型</td>
<td><select name="codeType">
<option value="1">单人单次</option>
<option value="0">多人共享单次</option>
</select> <span style="color: red;">1-单人单次 0-多人单次</span></td>
<td class=list_td01>生成数量</td>
<td class=list_td02><select name="num">
<option value="10">10</option>
<option value="100">100</option>
<option value="1000">1000</option>
<option value="10000">10000</option>
<option value="100000">100000</option>
</select></td>
</tr>
<tr align="left">
<td class="list_td01">开始时间</td>
<td class="list_td02"><input type="text"
onclick="displayCalendar(this,'yyyy-mm-dd hh:ii:00',this,true);"
class="datetime" id="startTime" name="startTime"> <span
style="color: red;">(必须)</span></td>
<td class="list_td01">结束时间</td>
<td class="list_td02"><input type="text"
onclick="displayCalendar(this,'yyyy-mm-dd hh:ii:00',this,true);"
class="datetime" id="endTime" name="endTime"> <span
style="color: red;">(必须)</span></td>
</tr>
<tr>
<td class=list_td01>奖励Json</td>
<td class=list_td02 colspan="3"><input type="text" size=90
name="rewardJson" id="rewardJson" value=""> <span
style="color: red;">(必须)</span></td>
</tr>
<tr>
<td class=list_td01>等级限制</td>
<td class=list_td02 colspan="1"><select name="level">
<option value="1">1级</option>
<option value="10">10级</option>
<option value="20">20级</option>
<option value="30">30级</option>
<option value="40">40级</option>
<option value="50">50级</option>
<option value="60">60级</option>
<option value="70">70级</option>
<option value="80">80级</option>
<option value="90">90级</option>
<option value="100">100级</option>
<option value="110">110级</option>
<option value="120">120级</option>
</select></td>
<td class=list_td01>生成批次</td>
<td class=list_td02 colspan="1"><input type="text" size=20
name="batch" id="batch" value="1"> <span
style="color: red;">(必须)</span></td>
</tr>
<tr>
<td align="left"><input type="button" class="butcom"
onclick="btnAjax()" value=" 生成提交 " /></td>
</tr>
</table>
<TABLE id="resultTable" align="left" class=common></TABLE>
<!-- select about -->
<table align="left" class=detail>
<tr>
<td class=list_td01>批次 </td>
<td class=list_td02><input type="text" size=10 name="selectbatch"
id="selectbatch" value="0"> <span
style="color: green;">(0表求所有批次)</span></td>
<td align="left"><input type="button" class="butcom"
onclick="selectAjax()" value=" 查询 " /></td>
<td align="left"><input type="button" class="butcom"
onclick="exportExcel()" value=" 导出excel " /></td>
</tr>
</table>
<TABLE id="selectTable" align="left" class=common></TABLE>
</form>
</body>
</HTML>
java、jsp导出excel功能备份的更多相关文章
- JAVA实现导出excel功能,封装通用导出工具类
引入maven <!--excel导出--> <dependency> <groupId>net.sourceforge.jexcelapi</groupId ...
- jsp导出Excel功能的实现
借助POI的excel接口,可以方便得实现excel导出功能: 首先需要引入poi对应的jar包 1.前端jsp页面需要一个a链接. web页面文件MIM类型的下载,只需要一个a元素,该a可以链到该文 ...
- 重构:以Java POI 导出EXCEL为例
重构 开头先抛出几个问题吧,这几个问题也是<重构:改善既有代码的设计>这本书第2章的问题. 什么是重构? 为什么要重构? 什么时候要重构? 接下来就从这几个问题出发,通过这几个问题来系统的 ...
- JSP导出Excel后身份证后三位为0
JSP导出Excel身份证号码超出Excel最大限制,用科学计数法表示,但后三位为0,修改方式: <style type="text/css">.txt { ...
- Atitit.导出excel功能的设计 与解决方案
Atitit.导出excel功能的设计 与解决方案 1.1. 项目起源于背景1 1.2. Js jquery方案(推荐)jquery.table2excel1 1.3. 服务器方案2 1.4. 详细 ...
- 项目笔记:导出Excel功能
1.前台这块: var ids=""; $.post("${basePath}/assets/unRegDeviceAction_getDeviceIds.do" ...
- java 实现导出Excel文件
java 实现导出Excel(java生成 excel 并导出文件) 经常有有一些数据需要导出成 excel 格式 ,所以就需要实现啦 开始: 1.加入jar poi-3.6-20091214. ...
- 项目笔记:导出Excel功能分sheet页插入数据
导出Excel功能分sheet页处理数据: /*导出EXCEL*/ public void createExcel() { log.info("导出Excel功能已经启动-BEGIN&quo ...
- vue项目导出EXCEL功能
因为一些原因导出EXCEL功能必须前端来做,所以就研究了一下,在网上也找了一些文章来看,有一些不完整,我做完了就记录下来,供大家参考: 1.首先先安装依赖: npm install file-save ...
随机推荐
- NX二次开发-UFUN打开选择文件夹对话框UF_UI_create_filebox
#include <uf.h> #include <uf_ui.h> #include <string> using namespace std; string O ...
- GTK+/GNOME编程(一)
1.开发环境:安装GTK+/GNOME库 #apt-get install gtk+-3.0 (安装GTK+库文件) #apt-get install gnome- ...
- mdk keil 指定变量、函数存储位置,使用 Scatter-Loading Description File, __attribute__(("section“))
0. 数据类型说明 主要包括4类: Code (inc. data) ,属于RO,也就是写的函数代码(包括代码中的变量) RO Data , 属于RO,使用const修饰的变量. RW Data, 属 ...
- SecureRandom的正确使用
目录 1. 什么是安全的随机数? 2. 怎么得到安全的随机数 3. SecureRandom最佳实践 3.1 基本用法 3.2 关于种子的设置 3.3 熵源不足时阻塞问题 4. 小结 1. 什么是安全 ...
- Python flask构建微信小程序订餐系统✍✍✍
Python flask构建微信小程序订餐系统 整个课程都看完了,这个课程的分享可以往下看,下面有链接,之前做java开发也做了一些年头,也分享下自己看这个视频的感受,单论单个知识点课程本身没问题, ...
- 13-MySQL-Ubuntu-数据表的查询-条件查询(二)
条件查询 1,比较查询(>,<,>=,<=,=)注:SQL查询语句的等于号(=) (1)查询学生表中年龄大于18岁的学生姓名和性别信息 select name,gender f ...
- HDU 5052 /// 树链剖分+线段树区间合并
题目大意: 给定n (表示树有n个结点) 接下来n行给定n个点的点权(在这个点上买鸡或者卖鸡的价钱就是点权) 接下来n-1行每行给定 x y 表示x结点和y结点之间有一条边 给定q (表示有q个询问) ...
- mac NTFS 关于错误-36,rm Input/output error
当传输文件时出现Mac错误代码36 当我向一个U盘或存储卡里传输文件时,出现了Mac Error Code36,我该如何解决? Mac,传输文件,错误代码36,U盘,卡片 Mac OS X Snow ...
- JS事件 卸载事件 当用户退出页面时(页面关闭、页面刷新等),触发onUnload事件,同时执行被调用的程序。注意:不同浏览器对onunload事件支持不同。
卸载事件(onunload) 当用户退出页面时(页面关闭.页面刷新等),触发onUnload事件,同时执行被调用的程序. 注意:不同浏览器对onunload事件支持不同. 如下代码,当退出页面时,弹出 ...
- [转]spring入门(六)【springMVC中各数据源配置】
在使用spring进行javaWeb开发的过程中,需要和数据库进行数据交换,为此要经常获取数据库连接,使用JDBC的方式获取数据库连接,使用完毕之后再释放连接,这种过程对系统资源的消耗无疑是很大的,这 ...