1、前台这块:

var ids="";
$.post("${basePath}/assets/unRegDeviceAction_getDeviceIds.do",function(res){
ids=res;
})
//创建Excel表
function btn_createExcel(){
ids=ids.replace("[","").replace("]","");
var data=ids.split(",");
var newAction ='/assets/unRegDeviceAction_createExcel.do?ids='+data;
createFun( newAction );
}
function createFun( newAction ){
if($.checkSession()){
var $form = $("#excelForm");
var action = "";
try {
action = $form.attr("action");
$form.attr("action","${basePath}"+newAction).submit();
}finally{
$form.attr("action",action);
}
}
}
/**
* 获取当前查询结果的设备的所有id
* @return
*/
public void getDeviceIds(){
List<String> ids= new ArrayList<String>();
if(queryBean == null){
queryBean = new UnRegDeviceQueryBean();
}
//-------数据过滤ST
log.info("数据过滤-ST");
@SuppressWarnings("unchecked")
Map<String, List<String>> mgrOrgMap = (Map<String, List<String>>) getSession().getAttribute(OrganizationUtil.ORG_MGR);
if(!OrganizationUtil.isNullMgrOrg(mgrOrgMap)){
Organization mgrOrg = new Organization();
mgrOrg.setMgrOrg(mgrOrgMap);
queryBean.setOrganization(mgrOrg);
} List<UnRegDevice> list= unRegDeviceService.query(queryBean);//查找UnRegDevice实体集合
for(UnRegDevice unRegDevice:list){
ids.add(unRegDevice.getId());
} print(ids.toString());
}

2、后台这块:

/*导出EXCEL*/
@SuppressWarnings("unused")
public void createExcel() {
log.info("导出Excel功能已经启动-BEGIN");
JxlUtil jsl = new JxlUtil();
List<UnRegDevice> dataList =new ArrayList<UnRegDevice>();
List<UnRegDeviceExport> list = new ArrayList<UnRegDeviceExport>();
List<Organization> organizations = null;
// 构建路径
String downLoadPath = "/WEB-INF/download/asset/";
String rootPath = getServletContext().getRealPath(downLoadPath);
String fileName = "";
File file=new File(rootPath); try {
if(!(file.exists()||file.isDirectory())){
file.mkdirs();
} if (null != getRequest().getParameter("ids")) {
String ids[] = getRequest().getParameter("ids").split(",");
for (int i = ; i < ids.length; i++) {
unRegDevice = unRegDeviceService.queryById(ids[i].replaceAll(" +",""));
dataList.add(unRegDevice);
}
}
if(dataList!=null){
for (UnRegDevice unRegDevice : dataList) {
UnRegDeviceExport unRegDeviceExport= new UnRegDeviceExport();
if(null!=unRegDevice.getId()){
unRegDeviceExport.setId(unRegDevice.getId());
}
if(null!=unRegDevice.getIp()){
unRegDeviceExport.setIp(unRegDevice.getIp());
}
if(null!=unRegDevice.getMac()){
unRegDeviceExport.setMac(unRegDevice.getMac());
}
if(null!=unRegDevice.getOrganization()){
log.info("获取设备全路径组织机构-ST");
Organization organization=unRegDevice.getOrganization();
String Aname =organization.getName();
String name= getAname(organization, Aname);
log.info("获取设备全路径组织机构-END--name:"+name);
unRegDeviceExport.setOrganizationName(name);
}
if(null!=unRegDevice.getHostName()){
unRegDeviceExport.setHostName(unRegDevice.getHostName());
}
if(null!=unRegDevice.getGroupName()){
unRegDeviceExport.setGroupName(unRegDevice.getGroupName());
}
if(null!=unRegDevice.getProtectState()){
unRegDeviceExport.setProtectState(unRegDevice.getProtectState());
}
if(null!=unRegDevice.getUpdateTime()){
SimpleDateFormat dateFormater = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String time=dateFormater.format(unRegDevice.getUpdateTime());
unRegDeviceExport.setUpdateTime(time);
}
if(null!=unRegDevice.getIsOpened()){
unRegDeviceExport.setIsOpened(unRegDevice.getIsOpened());
}
if(null!=unRegDevice.getIsFireWall()){
unRegDeviceExport.setIsFireWall(unRegDevice.getIsFireWall());
}
list.add(unRegDeviceExport);
}
}
log.info("数据过滤--END"); String interBase = "sys.column.name.unRegDevice";
String inter_value_key = "#isOpened#isFireWall#protectState#";
String[] inter_value_ary = { "isOpened.0", "isOpened.1","isFireWall.0", "isFireWall.1","protectState.0", "protectState.1"}; fileName = jsl.getInter(interBase.replace("column", "table"))
+ new Date().getTime();
String targetfile = rootPath + System.getProperty("file.separator")
+ fileName + ".xls";
// 创建可写入的Excel工作薄
WritableWorkbook wwb;
wwb = Workbook.createWorkbook(new File(targetfile));
// 创建Excel工作表
WritableSheet ws = wwb.createSheet("未注册设备", ); // 获取需要内容国际化的字段
jsl.creatCemsExcel(ws, list, interBase, inter_value_key,inter_value_ary); // 写入Exel工作表
wwb.write();
// 关闭Excel工作薄对象
wwb.close();
getResponse().setContentType(getServletContext().getMimeType(fileName));
getResponse().setHeader("Content-Disposition", "attachment;fileName="+new String(fileName.getBytes("gb2312"), "ISO8859-1")+".xls");
String fullFileName = getServletContext().getRealPath(downLoadPath + fileName+ ".xls");
InputStream in = new FileInputStream(fullFileName);
OutputStream out = getResponse().getOutputStream();
int b;
while((b=in.read())!= -){
out.write(b);
}
in.close();
out.close();
/* ServletActionContext.getRequest().setAttribute("downLoadPath",
downLoadPath);
ServletActionContext.getRequest().setAttribute("fileName",
fileName + ".xls");*/
this.msg = RESULT_SUCCESS;
log.info("导出EXCEL提示信息为:"+this.msg);
} catch (Exception e) {
log.error("export excel error:" + e.getMessage());
log.error("导出EXCEL失败");
}
log.info("导出Excel功能已经启动-END");
log.info("导出Excel功能已经启动-END");
/*return "downLoadUI";*/
} /*递归获取全路径组织机构方法*/
public String getAname(Organization organization, String oName){
log.info("递归获取全路径组织机构方法-ST");
if( organization.getParent()!=null){
String tName="";
tName=organization.getParent().getName()+"/"+oName;
log.info("递归获取全路径组织机构方法-END");
return getAname(organization.getParent(), tName);
}else{
log.info("递归获取全路径组织机构方法-END");
return oName;
}
}
public  void creatCemsExcel( WritableSheet ws, List<?> beanList, String internationalBase,
String value_str, String[] inter_value_ary ) throws Exception {
// -----------获取资源阶段----------------------------------------------------------------
String[] ary = internationalBase.split("\\.");
String beanName = ary[ary.length - ];
// 获得bean值(systable中保存的key)
beanName = beanName.substring(, ).toUpperCase()+ beanName.substring(, beanName.length());
// 获得要展现的字段名
ArrayList<String> key_list = getBeanKeys(beanName);
// 获取key的国际化用于国际化head
Map<String, String> key_inter = getInter(internationalBase, key_list);
// 获得需要国际化内容的Map
Map<String, String> interValueMap = getInter(internationalBase,inter_value_ary);// {ret.1=安装, ret.0=未安装}
// 标题
String title = getInter(internationalBase.replace("column", "table")); // -----------文件创建阶段----------------------------------------------------------------
try {
JSONArray json=getColumnLength(beanList, key_list);
// 写入表头 合并 (列 ->行 列->行)
ws.mergeCells(, , key_list.size() - , );
ws.addCell(new Label(, , title, wcf_title));
int startHead = ;
// 写入head
for (int i = ; i < key_list.size(); i++) {
ws.addCell(new Label(i, startHead, key_inter.get(key_list.get(i)), wcf_head));
for (int j = ; j < json.size(); j++) {
JSONObject jsonObj=json.getJSONObject(i);
if(jsonObj.get(key_list.get(i))!=null){
ws.setColumnView(i, Integer.parseInt(jsonObj.getString(key_list.get(i)))+);
}
}
} // 写入data
for (int i = , size = beanList.size(); i < size; i++) {// 循环行
for (int colNum = ; colNum < key_list.size(); colNum++) {// 循环列
HashMap<String, String> queryBeanMap = BeanReflect.beanToMap(beanList.get(i)); if (value_str == null || value_str.equals("")) {// 没有内容需要国际化
ws.addCell(new Label(colNum, startHead + i + ,queryBeanMap.get(key_list.get(colNum)),wcf_centre));
} else {
if (value_str.indexOf(("#" + key_list.get(colNum) + "#")) > -) {// 如果输入内容需要国际化
// 需要国际化
String interValue = interValueMap.get(key_list.get(colNum)+ "."+ queryBeanMap.get(key_list.get(colNum)));
ws.addCell(new Label(colNum, startHead + i + ,interValue, wcf_centre));
} else {
ws.addCell(new Label(colNum, startHead + i + ,queryBeanMap.get(key_list.get(colNum)),wcf_centre));
}
}
}
} // 写入结尾
ManagerSession managerSession = ManagerSessionUtils.getManagerSession(ServletActionContext.getRequest().getSession());
String niceName=getInter("sys.column.name.baseLog.creater")+" : "+managerSession.getNiceName();
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd kk:mm:ss ");
String time=getInter("sys.column.name.baseLog.createTime")+" : "+sdf.format(new Date());
ws.addCell(new Label(key_list.size()-, beanList.size()+, niceName, wcf_feet));
ws.addCell(new Label(key_list.size()-, beanList.size()+, time, wcf_feet));
/*if("DeviceIllegalConnectLog".equals(beanName)){
String msgName="违规外联日志导入必填项:{使用人 ,所属机构 ,MAC地址 ,设备名称, IP地址 ,发生时间, 存档时间,设备注册人账号,使用人账号}:注,***作为模板导入的时候请删除该提示行***";
ws.addCell(new Label(key_list.size()-16, beanList.size()+4, msgName, wcf_feet));
}*/
} catch (Exception e) {
e.printStackTrace();
}
}
// systable.xml中的展现key
private static ArrayList<String> getBeanKeys(String beanName) {
HttpServletRequest request = ServletActionContext.getRequest();
Map<?, ?> keyMap = (Map<?, ?>) request.getSession(false)
.getServletContext().getAttribute("vrvSysTablesAttr");
ArrayList<String> list = new ArrayList<String>();
SysTable sysTable = (SysTable) keyMap.get(beanName);
Set<SysColumn> set = sysTable.getColumns();
Iterator<SysColumn> it = set.iterator();
while (it.hasNext()) {
SysColumn column = it.next();
// 如果显示
if (column.getIsExport().toString().equals("Y")) {
list.add(column.getKey());
}
}
return list;
}

项目笔记:导出Excel功能的更多相关文章

  1. 公司项目笔记-导出excel

    一.asp.net中导出Excel的方法: 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出流写给浏览 ...

  2. 项目笔记:导出Excel功能分sheet页插入数据

    导出Excel功能分sheet页处理数据: /*导出EXCEL*/ public void createExcel() { log.info("导出Excel功能已经启动-BEGIN&quo ...

  3. vue项目导出EXCEL功能

    因为一些原因导出EXCEL功能必须前端来做,所以就研究了一下,在网上也找了一些文章来看,有一些不完整,我做完了就记录下来,供大家参考: 1.首先先安装依赖: npm install file-save ...

  4. Atitit.导出excel功能的设计 与解决方案

    Atitit.导出excel功能的设计 与解决方案 1.1. 项目起源于背景1 1.2. Js  jquery方案(推荐)jquery.table2excel1 1.3. 服务器方案2 1.4. 详细 ...

  5. Vue通过Blob对象实现导出Excel功能

    不同的项目有不同的导出需求,有些只导出当前所显示结果页面的表格进入excel,这个时候就有很多插件,比如vue-json-excel或者是Blob.js+Export2Excel.js来实现导出Exc ...

  6. 【angularjs】pc端使用angular搭建项目,实现导出excel功能

    此为简单demo. <!DOCTYPE html> <html ng-app="myApp"> <head> <meta charset= ...

  7. spring mvc项目中导出excel表格简单实现

    查阅了一些资料,才整理出spring mvc 项目导出excel表格的实现,其实很是简单,小计一下,方便以后查阅,也希望帮助有需要的朋友. 1.导入所需要依赖(Jar包).我使用的是maven,所以坐 ...

  8. 导出Excel功能的3种实现

    项目中总会用到Excel的导出功能,接触过好几个项目,发现有个项目的导出实现特别值得学习.这里学习顺带总结一下. 一.三种方法 我遇到的导出目前有3种处理: 每个功能一个导出方法: 写一个通用的Exp ...

  9. layui + mvc + ajax 导出Excel功能

    为了更方便,没基础的伙伴更容易理解,我尽量详细简便 省了很多代码,一步一步的试 自己引入文件 1. html 前端视图代码 Layui的数据绑定 全部代码 @{ Layout = null; } &l ...

随机推荐

  1. Java坦克大战 (五) 之产生敌方坦克和爆炸效果

    本文来自:小易博客专栏.转载请注明出处:http://blog.csdn.net/oldinaction 在此小易将坦克大战这个项目分为几个版本,以此对J2SE的知识进行回顾和总结,希望这样也能给刚学 ...

  2. linux基础了解的学习记录

    一.文件结构图 linux的储存结构为文件树 二.绝对路径.相对路径.权限 1.绝对路径: /usr/local/include       在路径的最前面是 / 开头的 使用环境:当在当前路径下想到 ...

  3. MySQL 的七种 join

    建表 在这里呢我们先来建立两张有外键关联的张表. CREATE DATABASE db0206; USE db0206; CREATE TABLE `db0206`.`tbl_dept`( `id` ...

  4. Java的Math-BigInteger-Random类概述

    1.      Math类 Math类在java.lang包中. 常用的方法有 Math.abs(double x)返回x的绝对值. Math.max(double x,double y)返回x和y的 ...

  5. Hibernate 配置文件与实体类

    今天在配置Hibernate的时候碰到了这样的错误: MappingException: Unknown entity 仔细想了一下,应该是因为我在开始时使用了 Configuration confi ...

  6. hdu2825(AC 自动机)

    hdu2825 题意 给出一些字符串,要求构造一个长度为 \(n\) 的字符串至少包括其中的 \(k\) 个,问有多少种字符串满足条件. 分析 AC自动机 构造状态转移,然后 状态压缩DP 即可. \ ...

  7. ret2dir:Rethinking Kernel Isolation(翻译)

    前一段时间在网上找ret2dir的资料,一直没找到比较系统的介绍,于是干脆把这篇经典的论文翻译了,当然,第一次翻译(而且还这么长),很多词汇不知道到底该怎么翻译,而且最近事情也比较多, 翻译得挺烂的, ...

  8. XSS && CRLF && property&attribute

    XSS cross-site scripting 跨站点脚本,为了避免与css冲突,命名为XSS.它是将恶意代码作为一个网页内容,这些恶意代码会注入到用户的浏览器中并执行,从而使用户受到攻击,常见的有 ...

  9. RabbitMQ (三) 工作队列之轮询分发

    上一篇讲了简单队列,实际工作中,这种队列应该很少用到,因为生产者发送消息的耗时一般都很短,但是消费者收到消息后,往往伴随着对高消息的业务逻辑处理,是个耗时的过程,这势必会导致大量的消息积压在一个消费者 ...

  10. 【强连通分量缩点】【记忆化搜索】bzoj1589 [Usaco2008 Dec]Trick or Treat on the Farm 采集糖果

    缩成DAG f(i)表示以i为起点的最长路 #include<cstdio> #include<cstring> #include<algorithm> #incl ...