文档章节

struts2导出Excel文件

岳静
 岳静
发布于 2012/07/19 21:12
字数 326
阅读 2425
收藏 7

    这里说下struts2导出Excel文件的列子。

    列子比较简单。下面是我们导出Excel需要的jar包。

  struts2需要jar包:commons-logging.jarfreemarker-2.3.8.jarognl-2.6.11.jarstruts2-core-2.0.11.1.jarxwork-2.0.4.jar

excel导出:jxl.jar

下面为配置web.xml的内容:

.....             
	<filter>   
	    <filter-name>struts2</filter-name>   
	    <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>   
	</filter>   
	<filter-mapping>   
	    <filter-name>struts2</filter-name>   
	    <url-pattern>/*</url-pattern>   
	</filter-mapping>   
......

下面为struts2的配置文件代码[filename为导出时弹出来的名称]:

<?xml version="1.0" encoding="UTF-8"?>   
	<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apache.org/dtds/struts-2.0.dtd" >   
	<struts>   
	    <package name="platform-default" extends="struts-default">   
	        <action name="excel" class="action.ExcelAction">   
                 <result name="excel" type="stream">   
	                <param name="contentType">   
	                    application/vnd.ms-excel   
	                </param>   
	                <param name="inputName">excelStream</param>   
	                <param name="contentDisposition">   
	                    filename="export.xls"  
	                </param>   
	                <param name="bufferSize">1024</param>   
	            </result>   
	        </action>   
	    </package>   
	</struts>

Action的代码:

package action;   
	  
	import java.io.InputStream;   
	import service.IExcelService;   
	import service.impl.ExcelServiceImpl;   
	public class ExcelAction {
	 
	    InputStream excelStream;
	    public String execute(){   
	        IExcelService es = new ExcelServiceImpl();   
	        excelStream = es.getExcelInputStream();   
	        return "excel";   
	    }   
	    //get set...   
	}

Service的接口代码:

package service;   
	import java.io.InputStream;   
	public interface IExcelService {   
	    InputStream getExcelInputStream();   
	}

Service代码:

package service.impl;   
	  
	import java.io.ByteArrayInputStream;   
	import java.io.ByteArrayOutputStream;   
	import java.io.InputStream;   
	import java.io.OutputStream;   
	  
	import jxl.Workbook;   
	import jxl.write.WritableSheet;   
	import jxl.write.WritableWorkbook;   
	import service.IExcelService;   
	  
	public class ExcelServiceImpl implements IExcelService {   
	  
	    @Override   
	    public InputStream getExcelInputStream() {   
	        //将OutputStream转化为InputStream   
	        ByteArrayOutputStream out = new ByteArrayOutputStream();   
	        putDataOnOutputStream(out);   
	        return new ByteArrayInputStream(out.toByteArray());   
	    }   
	  
	    private void putDataOnOutputStream(OutputStream os) {   
	        jxl.write.Label label;   
	        WritableWorkbook workbook;   
	        try {   
	            workbook = Workbook.createWorkbook(os);   
	            WritableSheet sheet = workbook.createSheet("Sheet1", 0);   
	  
	            label = new jxl.write.Label(0, 0, "struts2导出excel");   
	            sheet.addCell(label);   
	               
	            workbook.write();   
	            workbook.close();   
	        } catch (Exception e) {   
	            e.printStackTrace();   
	        }   
	    }   
	}

主要事项:例子中OutputStreamInputStream是一种简单的实现,但是需要内存比较多

© 著作权归作者所有

岳静

岳静

粉丝 45
博文 19
码字总数 8678
作品 0
深圳
高级程序员
私信 提问
日常记录(二)SpringMVC导出Excel

前言 相信很多朋友在实际工作中都会要将数据导出成Excel的需求,通常这样的做法有两种。 一是采用JXL来生成Excel,之后保存到服务器,然后在生成页面之后下载该文件。 二是使用POI来生成Exc...

crossoverJie
2016/07/10
224
1
ssh2导出excel

写了一个关于struts2导出excel的方法,后台为报错,但找不到相应的文件,不知是哪里错了,求指教? 前台 后台 struts.xml action excel生成类

求一个网名
2015/09/05
556
3
struts2笔记——整合JasperReports

JasperReports,Jasper .[dʒæspə]碧玉 16.1 JasperReports简介 JasperReport是一个强大、灵活的报表生成工具,能够展示丰富的页面内容,并将之转换成Excel、PDF、HTML或者XML格式。这个工...

梅_95
2016/08/16
31
0
shenzhanwang/S2SH

S2SH Struts2,Hibernate,Spring三大框架的整合总是很麻烦,在此提供一个已经整合好三大框架的包,可以直接下载导入Myeclipse使用,项目基于Maven做依赖管理。 其中包含的内容如下: 1.Struts...

shenzhanwang
2016/11/16
0
0
J2EE框架--iMvc

iMvc是以DWZ、Struts2、Spring3、Hibernate3为核心,来快速开发JavaEE企业级应用的开源框架组合。 iMvc框架组合: DWZ:富客户端框架 Struts2:使用Struts2 REST Spring3:使用AOP、IOC、事物...

匿名
2012/01/08
60.6K
1

没有更多内容

加载失败,请刷新页面

加载更多

3_数组

3_数组

行者终成事
今天
7
0
经典系统设计面试题解析:如何设计TinyURL(二)

原文链接:https://www.educative.io/courses/grokking-the-system-design-interview/m2ygV4E81AR 编者注:本文以一道经典的系统设计面试题:《如何设计TinyURL》的参考答案和解析为例,帮助...

APEMESH
今天
7
0
使用logstash同步MySQL数据到ES

概述   在生成业务常有将MySQL数据同步到ES的需求,如果需要很高的定制化,往往需要开发同步程序用于处理数据。但没有特殊业务需求,官方提供的logstash就很有优势了。   在使用logstas...

zxiaofan666
今天
10
0
X-MSG-IM-分布式信令跟踪能力

经过一周多的鏖战, X-MSG-IM的分布式信令跟踪能力已基本具备, 特点是: 实时. 只有要RX/TX就会实时产生信令跟踪事件, 先入kafka, 再入influxdb待查. 同时提供实时sub/pub接口. 完备. 可以完整...

dev5
今天
7
0
OpenJDK之CyclicBarrier

OpenJDK8,本人看的是openJDK。以前就看过,只是经常忘记,所以记录下 图1 CyclicBarrier是Doug Lea在JDK1.5中引入的,作用就不详细描述了,主要有如下俩个方法使用: await()方法,如果当前线...

克虏伯
今天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部