struts2: 通过流输出实现exce导出

简介: 参考下面代码,在Action中加一个方法: 1 // 导出excel 2 public String excel() throws Exception { 3 StringBuffer excelBuf = new StringBuffer(); 4 excelBuf.

参考下面代码,在Action中加一个方法:

 1     // 导出excel
 2     public String excel() throws Exception {
 3     StringBuffer excelBuf = new StringBuffer();
 4     excelBuf.append("运单号").append("\t").append("始发站").append("\t").append("目的站").append("\n");
 5     excelBuf.append("112-00100100").append("\t").append("PEK").append("\t").append("SHA").append("\n");
 6     excelBuf.append("112-00100111").append("\t").append("PVG").append("\t").append("XIY").append("\n");
 7     excelBuf.append("112-00100122").append("\t").append("SHA").append("\t").append("HHY").append("\n");
 8     String excelString = excelBuf.toString();
 9     excelStream = new ByteArrayInputStream(excelString.getBytes(), 0, excelString.getBytes().length);
10     return "excel";
11     }

实质上是一个格式化的cvs文本文件,但是所有的excel/wps都能识别这种格式,导出的数据量不大,且没有复杂的线框格式要求时,这种处理方式最为方便

 

struts2的配置文件:

 1 <package name="cba_index" ...>
 2     ...
 3     <action name="index_*" method="{1}" class="CbaAction">
 4         <result name="success">/mu-reservation/cba/index.jsp</result>            
 5         <!-- 导出excel -->
 6         <result name="excel" type="stream">
 7             <param name="contentType">application/vnd.ms-excel</param>    <!-- 注意这里的ContentType -->
 8             <param name="inputName">excelStream</param>                   <!-- 这里需要和Action里的变量名一致 -->
 9             <param name="contentDisposition">filename="download.xls"</param> <!-- 下载文件的名字 -->
10             <param name="bufferSize">10240</param>  <!-- 下载文件的大小 10485760=10M -->
11         </result>
12     </action>
13     ...
14 </package>

页面上

1 <a href="index_excel.do" target="_blank">导出excel示例</a>

导出后的文件打开效果:

目录
相关文章
|
6月前
|
Java
Springboot 导出word,动态填充表格数据
Springboot 导出word,动态填充表格数据
|
5月前
|
前端开发 应用服务中间件 PHP
解决php因为输出内容太短无法流式(Stream)输出问题
本文探讨了PHP流式输出的问题,指出当每次`echo`的内容过短时,前端可能无法实时接收。通过测试发现,需达到一定长度(如1024字节)时流式输出才会生效。为解决此问题,建议在PHP代码中检查输出内容长度,不足时拼接特殊标记,前端接收到后通过正则表达式移除。示例代码提供了解决方案,文章鼓励读者留言讨论和点赞分享。关注作者微信公众号【xdub】获取更多相关内容。
55 2
|
5月前
|
Java
使用java文件过滤器输出制定格式文件路径
使用java文件过滤器输出制定格式文件路径
|
6月前
|
分布式计算 Hadoop 数据格式
MapReduce的输入和输出数据格式有哪些?请举例说明。
MapReduce的输入和输出数据格式有哪些?请举例说明。
113 0
|
11月前
|
JSON Java 数据格式
SpringBoot 统一响应返回格式格式 数组
SpringBoot 统一响应返回格式格式 数组
|
JSON 前端开发 Java
springMVC自定义的消息转换器解决格式转化
springMVC自定义的消息转换器解决格式转化
88 0
|
JSON 前端开发 数据格式
ThinkPHP6.0日志没有输出到文件而是直接输出到了输出流
ThinkPHP6.0日志没有输出到文件而是直接输出到了输出流
173 0
|
XML JSON 数据格式
解析如何读取json文件数据并转换为xml并保存起来
解析如何读取json文件数据并转换为xml并保存起来
380 0
解析如何读取json文件数据并转换为xml并保存起来
|
XML JSON 搜索推荐
SpringMVC:多视图[JSP,JSON,Excel,XML]混合输出__Java配置方式
SpringMVC:多视图[JSP,JSON,Excel,XML]混合输出__Java配置方式
161 0
|
XML JSON 前端开发
SpringMVC:多视图[JSP,JSON,Excel,XML]混合输出__XML配置方式
SpringMVC:多视图[JSP,JSON,Excel,XML]混合输出__XML配置方式
152 0