在利用网页展示查询结果,经常会遇到要求导出成Excel的需求。采用这种方法可以定制输出的格式和内容(还不支持合并单元格和公式),生成真正的Excel格式(不是csv)的Excel。
一、struts.xml
<?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>
<constant name="struts.i18n.encoding" value="UTF-8"/>
<package name="demo" extends="struts-default">
<action name="excel" method="execute" class="demo.ExcelAction">
<result name="excel" type="stream">
<param name="contentType">application/vnd.ms-excel</param> <!-- 注意这里的ContentType -->
<param name="inputName">excelStream</param> <!-- 这里需要和Action里的变量名一致 -->
<param name="contentDisposition">filename="standard.xls"</param>
<param name="bufferSize">1024</param>
</result>
</action>
</package>
</struts>
二、Struts2的 Action
package demo;
public class ExcelAction {
private InputStream excelStream; // 需要生成getter和setter
public String execute() throws Exception {
StringBuffer excelBuf = new StringBuffer();
excelBuf.append("BookName").append("\t").append("Year").append("\t").append("author").append("\n");
excelBuf.append("Thinking in Java").append("\t").append("2001").append("\t").append("Eckel").append("\n");
excelBuf.append("Spring in action").append("\t").append("2005").append("\t").append("Rod").append("\n");
String excelString = excelBuf.toString();
logger.debug("result excel String: " + excelString);
excelStream = new ByteArrayInputStream(excelString.getBytes(), 0, excelString.length());
return "excel";
}
// getter and setter
...
}
三、Jsp页面
<%@ taglib prefix="s" uri="/struts-tags"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<s:head />
</head>
<body>
<s:form action="" method="post">
<s:submit key="button.submit"/>
</s:form>
</body>
</html>
转自:http://www.blogjava.net/usherlight/archive/2008/06/23/210135.html
分享到:
相关推荐
Struts2 和 Apache POI 的结合使用...通过以上步骤,可以成功利用 Struts2 和 Apache POI 实现 Web 应用程序中的 Excel 导出功能。这个功能广泛应用于数据分析、报表生成、数据交换等多种场景,极大地提高了工作效率。
以下将详细介绍如何利用Struts2和POI实现Excel导出。 首先,你需要在项目中引入Apache POI库。在上述描述中提到的版本是`poi-bin-3.2-FINAL-20081019.zip`,但请确保使用当前的稳定版本,因为随着时间的推移,POI会...
6. **Struts2配置**:在Struts2的配置文件(struts.xml)中,定义一个导出Excel的Action,返回类型设置为流类型(通常为“stream”),并将生成的Excel内容设置到HttpServletResponse的输出流中。 7. **Action实现*...
在"struts2+jxl导出excel"的场景中,我们将讨论如何利用Struts2框架与JXL库配合,实现从web应用中导出数据到Excel的工作。 首先,我们需要理解Struts2的动作(Action)和结果(Result)。动作是处理用户请求的核心...
1. `<result name="success" type="stream">`:指定当 Action 执行成功后,返回的结果类型为流,这使得我们可以直接将生成的 Excel 文件内容输出到浏览器。 2. `<param name="contentType">application/vnd.ms-excel...
总结来说,"struts2+poi实现导出Excel文件.docx"的实现方式是利用Struts2的Action和结果类型配置,结合Apache POI库生成Excel文件,并通过HTTP响应返回给客户端,实现数据的导出功能。这一过程涉及了MVC模式、HTTP...
总结来说,利用Struts2和Apache POI,我们可以方便地实现Excel文件的导出。开发者只需要编写Action类,处理数据并创建Excel工作簿,然后在Struts2配置中定义动作和结果,就可以在Web应用中提供导出功能。这种技术在...
在"Struts2+JXL 下载 Excel 文档"的场景中,开发者通常会创建一个Action,这个Action负责生成Excel文档并提供下载。用户通过浏览器访问特定URL,Struts2框架接收到请求后,会路由到相应的Action。Action内部会利用...
下面将详细介绍如何在Struts2中利用POI在内存中生成Excel文件并提供下载。 首先,了解Apache POI的基本用法。POI提供了HSSFWorkbook类,用于处理Excel的XLS格式,而XSSFWorkbook则处理XLSX格式。这里我们主要讨论...
7. **优化与扩展**:为了提高性能,可以考虑缓存已编译的报表模板,或者利用Struts2的拦截器进行权限控制、日志记录等操作。 总的来说,Struts2和JasperReport的结合使得Java Web应用能够方便地生成和展示动态报表...
本文将详细讲解如何利用Struts2处理集合数组并将其转化为XLS文件。 首先,我们需要一个`List<Object>`类型的集合,其中每个Object可以是包含多个属性的数据实体,这些属性将作为Excel文件中的列数据。例如,我们有...
2. **Struts 配置**:在 Struts 的配置文件(如 `struts.xml`)中,你需要定义一个与请求匹配的 Action,设置返回类型为 `stream`,以便能够返回二进制流,即 Excel 文件。例如: ```xml <result type="stream...
- `org.apache.struts2.ServletActionContext`: 获取请求和响应对象。 - `dao.DBUtil`: 数据库连接工具类。 #### 2. 导出 Excel 的方法 ```java public void pubexportExcel(Map parameters, String url) throws ...
3. 配置Struts2的Action方法作为报表生成的入口,同时定义对应的Result类型,如jasper或stream。 4. 在Action中调用JasperReport API,利用之前准备好的数据填充报表。 5. 设置报表输出格式,然后通过流式响应返回给...