本文转自 http://lingceng.iteye.com/blog/1820081/

Displaytag官网有1.01.11.2等,注意找到对应的版本。源码和API可以在Maven库中找到。 
  常规的使用不是问题,这里说说关于Excel导出的问题,中文乱码,使用POI等。我使用的是Displaytag1.1。

基本导出功能 
  这种情况只需引入displaytag-1.1.jar。 
  设置column属性media="html"将不会导出,media="excel"不会页面显示,默认既显示又导出。 
  setProperty也可以写在displaytag.properties中应用于所有表格。

  1. <display:table name="test" export="true" id="currentRowObject">
  2. <display:column property="id" title="ID" />
  3. <display:column property="email" />
  4. <display:column property="status" />
  5. <display:column media="html" property="date" />
  6. <display:setProperty name="export.excel" value="true" />
  7. <display:setProperty name="export.excel.filename" value="export.xls" />
  8. </display:table>

这时候导出的excel打开的时候office会报警,但是能够打开,因为这不是正真的excel,只是csv改了后缀的纯文本格式。可能出现中文乱码,通过重载ExcelView来解决。

  1. Class SimpleChineseExcelView extends ExcelView {
  2. public String getMimeType(){
  3. //原代码是return "application/vnd.ms-excel";
  4. return "application/vnd.ms-excel;charset=gbk";
  5. }
  6. }

修改displaytag.properties中对应条目: 
  export.excel.class=yourpackage.SimpleChineseExcelView 
  
  这样就勉强能用了,只要能够忍受每次都需要另存为excel来避免报警,不用中文文件名,不在bodycontent中使用中文。这样的实现只能是差强人意。中文问题解决

使用POI 
  需要引入额外的displaytag-export-excel-1.1.jar,使用Maven解决依赖。 
  修改displaytag.properties中对应条目: 
  export.excel.class=org.displaytag.export.excel.ExcelHssfView 
  配置export filter

  1. <!--Configure the Filter in your web.xml:-->
  2. <filter>
  3. <filter-name>ResponseOverrideFilter</filter-name>
  4. <filter-class>org.displaytag.filter.ResponseOverrideFilter</filter-class>
  5. </filter>
  6. <!--And add mappings for urls the filter will intercept, for example:-->
  7. <filter-mapping>
  8. <filter-name>ResponseOverrideFilter</filter-name>
  9. <url-pattern>*.do</url-pattern>
  10. </filter-mapping>
  11. <filter-mapping>
  12. <filter-name>ResponseOverrideFilter</filter-name>
  13. <url-pattern>*.jsp</url-pattern>
  14. </filter-mapping>

filter-mapping加在struts之前,acegi之后(如果有),放struts之后会出问题。 
  很好地解决各种中文问题,也是真正的excel。

实践Hack: 
  项目中已经有了poi3.6,而displaytag-export-excel-1.1依赖的是poi3.0,版本太高,需要重新写一个ExcelHssfView。其实很简单,找到ExcelHssfView的源码,删除其中的所有的setEncoding方法,setEncoding方法在poi3.6中没有。修改后的代码如下,当然记得修改export.excel.class:

  1. package com.lingceng;
  2.  
  3. import java.io.OutputStream;
  4. import java.util.Calendar;
  5. import java.util.Date;
  6. import java.util.Iterator;
  7.  
  8. import javax.servlet.jsp.JspException;
  9.  
  10. import org.apache.commons.lang.ObjectUtils;
  11. import org.apache.commons.lang.StringEscapeUtils;
  12. import org.apache.commons.lang.StringUtils;
  13. import org.apache.poi.hssf.usermodel.HSSFCell;
  14. import org.apache.poi.hssf.usermodel.HSSFCellStyle;
  15. import org.apache.poi.hssf.usermodel.HSSFFont;
  16. import org.apache.poi.hssf.usermodel.HSSFRow;
  17. import org.apache.poi.hssf.usermodel.HSSFSheet;
  18. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  19. import org.apache.poi.hssf.util.HSSFColor;
  20. import org.displaytag.Messages;
  21. import org.displaytag.exception.BaseNestableJspTagException;
  22. import org.displaytag.exception.SeverityEnum;
  23. import org.displaytag.export.BinaryExportView;
  24. import org.displaytag.model.Column;
  25. import org.displaytag.model.ColumnIterator;
  26. import org.displaytag.model.HeaderCell;
  27. import org.displaytag.model.Row;
  28. import org.displaytag.model.RowIterator;
  29. import org.displaytag.model.TableModel;
  30.  
  31. /**
  32. * Excel exporter using POI HSSF.
  33. * @author Fabrizio Giustina
  34. * @author rapruitt
  35. * @version $Revision: 1.2 $ ($Author: fgiust $)
  36. */
  37. public class MyExcelHssfView implements BinaryExportView
  38. {
  39.  
  40. /**
  41. * TableModel to render.
  42. */
  43. private TableModel model;
  44.  
  45. /**
  46. * export full list?
  47. */
  48. private boolean exportFull;
  49.  
  50. /**
  51. * include header in export?
  52. */
  53. private boolean header;
  54.  
  55. /**
  56. * decorate export?
  57. */
  58. private boolean decorated;
  59.  
  60. /**
  61. * Generated sheet.
  62. */
  63. private HSSFSheet sheet;
  64.  
  65. /**
  66. * @see org.displaytag.export.ExportView#setParameters(TableModel, boolean, boolean, boolean)
  67. */
  68. public void setParameters(TableModel tableModel, boolean exportFullList, boolean includeHeader,
  69. boolean decorateValues)
  70. {
  71. this.model = tableModel;
  72. this.exportFull = exportFullList;
  73. this.header = includeHeader;
  74. this.decorated = decorateValues;
  75. }
  76.  
  77. /**
  78. * @return "application/vnd.ms-excel"
  79. * @see org.displaytag.export.BaseExportView#getMimeType()
  80. */
  81. public String getMimeType()
  82. {
  83. return "application/vnd.ms-excel"; //$NON-NLS-1$
  84. }
  85.  
  86. /**
  87. * @see org.displaytag.export.BinaryExportView#doExport(OutputStream)
  88. */
  89. public void doExport(OutputStream out) throws JspException
  90. {
  91. try
  92. {
  93. HSSFWorkbook wb = new HSSFWorkbook();
  94. sheet = wb.createSheet("-");
  95.  
  96. int rowNum = 0;
  97. int colNum = 0;
  98.  
  99. if (this.header)
  100. {
  101. // Create an header row
  102. HSSFRow xlsRow = sheet.createRow(rowNum++);
  103.  
  104. HSSFCellStyle headerStyle = wb.createCellStyle();
  105. headerStyle.setFillPattern(HSSFCellStyle.FINE_DOTS);
  106. headerStyle.setFillBackgroundColor(HSSFColor.BLUE_GREY.index);
  107. HSSFFont bold = wb.createFont();
  108. bold.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
  109. bold.setColor(HSSFColor.WHITE.index);
  110. headerStyle.setFont(bold);
  111.  
  112. Iterator iterator = this.model.getHeaderCellList().iterator();
  113.  
  114. while (iterator.hasNext())
  115. {
  116. HeaderCell headerCell = (HeaderCell) iterator.next();
  117.  
  118. String columnHeader = headerCell.getTitle();
  119.  
  120. if (columnHeader == null)
  121. {
  122. columnHeader = StringUtils.capitalize(headerCell.getBeanPropertyName());
  123. }
  124.  
  125. HSSFCell cell = xlsRow.createCell((short) colNum++);
  126. cell.setCellValue(columnHeader);
  127. cell.setCellStyle(headerStyle);
  128. //cell.setEncoding(HSSFCell.ENCODING_UTF_16);
  129. }
  130. }
  131.  
  132. // get the correct iterator (full or partial list according to the exportFull field)
  133. RowIterator rowIterator = this.model.getRowIterator(this.exportFull);
  134. // iterator on rows
  135.  
  136. while (rowIterator.hasNext())
  137. {
  138. Row row = rowIterator.next();
  139. HSSFRow xlsRow = sheet.createRow(rowNum++);
  140. colNum = 0;
  141.  
  142. // iterator on columns
  143. ColumnIterator columnIterator = row.getColumnIterator(this.model.getHeaderCellList());
  144.  
  145. while (columnIterator.hasNext())
  146. {
  147. Column column = columnIterator.nextColumn();
  148.  
  149. // Get the value to be displayed for the column
  150. Object value = column.getValue(this.decorated);
  151.  
  152. HSSFCell cell = xlsRow.createCell((short) colNum++);
  153. //cell.setEncoding(HSSFCell.ENCODING_UTF_16);
  154.  
  155. if (value instanceof Number)
  156. {
  157. Number num = (Number) value;
  158. cell.setCellValue(num.doubleValue());
  159. }
  160. else if (value instanceof Date)
  161. {
  162. cell.setCellValue((Date) value);
  163. }
  164. else if (value instanceof Calendar)
  165. {
  166. cell.setCellValue((Calendar) value);
  167. }
  168. else
  169. {
  170. cell.setCellValue(escapeColumnValue(value));
  171. }
  172.  
  173. }
  174. }
  175. wb.write(out);
  176. }
  177. catch (Exception e)
  178. {
  179. throw new ExcelGenerationException(e);
  180. }
  181. }
  182.  
  183. // patch from Karsten Voges
  184. /**
  185. * Escape certain values that are not permitted in excel cells.
  186. * @param rawValue the object value
  187. * @return the escaped value
  188. */
  189. protected String escapeColumnValue(Object rawValue)
  190. {
  191. if (rawValue == null)
  192. {
  193. return null;
  194. }
  195. String returnString = ObjectUtils.toString(rawValue);
  196. // escape the String to get the tabs, returns, newline explicit as \t \r \n
  197. returnString = StringEscapeUtils.escapeJava(StringUtils.trimToEmpty(returnString));
  198. // remove tabs, insert four whitespaces instead
  199. returnString = StringUtils.replace(StringUtils.trim(returnString), "\\t", " ");
  200. // remove the return, only newline valid in excel
  201. returnString = StringUtils.replace(StringUtils.trim(returnString), "\\r", " ");
  202. // unescape so that \n gets back to newline
  203. returnString = StringEscapeUtils.unescapeJava(returnString);
  204. return returnString;
  205. }
  206.  
  207. /**
  208. * Wraps IText-generated exceptions.
  209. * @author Fabrizio Giustina
  210. * @version $Revision: 1.2 $ ($Author: fgiust $)
  211. */
  212. static class ExcelGenerationException extends BaseNestableJspTagException
  213. {
  214.  
  215. /**
  216. * D1597A17A6.
  217. */
  218. private static final long serialVersionUID = 899149338534L;
  219.  
  220. /**
  221. * Instantiate a new PdfGenerationException with a fixed message and the given cause.
  222. * @param cause Previous exception
  223. */
  224. public ExcelGenerationException(Throwable cause)
  225. {
  226. super(ExcelHssfView.class, Messages.getString("ExcelView.errorexporting"), cause); //$NON-NLS-1$
  227. }
  228.  
  229. /**
  230. * @see org.displaytag.exception.BaseNestableJspTagException#getSeverity()
  231. */
  232. public SeverityEnum getSeverity()
  233. {
  234. return SeverityEnum.ERROR;
  235. }
  236. }
  237.  
  238. }

displaytag的Excel导出实践的更多相关文章

  1. java 导出 excel 最佳实践,java 大文件 excel 避免OOM(内存溢出) excel 工具框架

    产品需求 产品经理需要导出一个页面的所有的信息到 EXCEL 文件. 需求分析 对于 excel 导出,是一个很常见的需求. 最常见的解决方案就是使用 poi 直接同步导出一个 excel 文件. 客 ...

  2. appfuse:Excel导出

    1.pom.xml <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi< ...

  3. VB-机房收费系统之Excel导出

    敲机房很久了,感觉对代码的感知力终于有所提高了,很是开心.今天在敲学生充值记录查询的时候发现,其中有了新的知识,  这时候就该到了分析问题的时候了.不说废话了! 首先 保证自己的笔记本或者电脑上必须有 ...

  4. 百万级别数据Excel导出优化

    前提 这篇文章不是标题党,下文会通过一个仿真例子分析如何优化百万级别数据Excel导出. 笔者负责维护的一个数据查询和数据导出服务是一个相对远古的单点应用,在上一次云迁移之后扩展为双节点部署,但是发现 ...

  5. [moka同学笔记]PHPexcel之excel导出和导入

    原案例来自http://www.sucaihuo.com/有修改 1.目录结构(文件不用解释,应该都可以看得懂,直接看代码)

  6. 偷懒小工具 - Excel导出公共类

    说明 最近接了一个任务,就是做一个列表的Excel导出功能.并且有很多页面都会使用这个功能. 导出的Excel大体格式如图 很简单的列表,标题加背景色,然后不同类型,显示方式不一样.对齐方式不一样.不 ...

  7. 转:POI操作Excel导出

    package com.rd.lh.util.excel; import java.beans.PropertyDescriptor; import java.io.FileOutputStream; ...

  8. TP5.0源生Excel导出

    PHPExcel类在TP5里边并不能很好的兼容,使用起来很麻烦. 不像是tp3.2那样直接import()加进来就能new,因为它里边的命名空间找不到.总是说undefined class. 如果是使 ...

  9. java反射学习之二万能EXCEL导出

    一.EXCEL导出的实现过程 假设有一个对象的集合,现在需要将此集合内的所有对象导出到EXCEL中,对象有N个属性:那么我们实现的方式是这样的: 循环这个集合,在循环集合中某个对象的所有属性,将这个对 ...

随机推荐

  1. 【WebKit内核 CEF3 】 第一篇:下载分支代码并本地编译

    关于CEF  Chromium Embedded Framework 简单说就是  WebKit内核的 对外绑定. 当前主流浏览器内核 一.Trident内核代表产品Internet Explorer ...

  2. 如何架设部署V2EX社区/论坛(Google App Engine版)

    1.What's V2EX? 关于这个问题,我们可以看看其作者Livid早期自己的V2EX社区的介绍: What's V2EX? 这是很多人都问过的问题,而我一直都没有做出一个明确的解答.因为我实在觉 ...

  3. 转发:微信小程序-template模板使用

    转载于CSDN--[向朔1992]处.(部分内容根据实际情况有所修改) 小程序实现主页面调用次级页面的wxml页面内容,如下图:   根据上图,我们可以将图片和图片信息作为一个goodsList.wx ...

  4. DP较为完整的知识

    数位DP 这类题,才刚刚接触,记得去年网络赛,就有道这样的题,我完全不会, 对于这类题基本方法是,是利用数的位数来构造转移方程. 下面给出两篇论文的链接: <数位计数问题解法研究> < ...

  5. 使用SoapUI生成WS请求报文

    WSDL地址示例:http://10.1.84.10:8100/webService/common/mail?wsdl   打开SoapUI,创建一个Project,输入wsdl地址就ok. 1.访问 ...

  6. HDFS配额管理指南

    原文地址:http://hadoop.apache.org/docs/r1.0.4/cn/hdfs_quota_admin_guide.html Hadoop分布式文件系统(HDFS)允许管理员为每个 ...

  7. Python学习笔记015——readline与readlines的区别

    示例1 读取同样一个文件binary_read_1.txt. 春眠不觉晓,处处闻啼鸟. 夜来风雨声,花落知多少. 其中该文件内容被下段代码读出(注意,这里是采用的readlines) f = open ...

  8. Android特性与系统架构

    Android特性与系统架构 一.Android特性 • 应用程序框架支持组件的重用与替换 • Dalvik 虚拟机专为移动设备优化 • 集成的浏览器基于开源的WebKit 引擎 • 优化的图形库包括 ...

  9. X86 寻址方式、AT&T 汇编语言相关知识、AT&T 与 Intel 汇编语言的比较、gcc 嵌入式汇编

    注:本分类下文章大多整理自<深入分析linux内核源代码>一书,另有参考其他一些资料如<linux内核完全剖析>.<linux c 编程一站式学习>等,只是为了更好 ...

  10. Linux标识进程

    一.前言 其实两年前,本站已经有了一篇关于进程标识的文档,不过非常的简陋,而且代码是来自2.6内核.随着linux container.pid namespace等概念的引入,进程标识方面已经有了天翻 ...