最近做的项目中用到了displaytag,displaytag还是一个相当不错的分页标签,功能比较强大,最重要的是开源的。项目中部分列表需要实现导出excel和pdf。直接采用displaytag的导出,发现有两个问题,第一就是中文问题,excel和csv中都会有乱码,pdf却是中文无法显示.第二个就是导出时会把table中的html标签也导出来。
解决的中文问题方法
对于Csv 在getMimeType()中加上字符集 charset=GBK
public String getMimeType() { return "text/csv;charset=GBK"; //$NON-NLS-1$ }
对于Excel 只要用ExcelHssfView 类就可以了
对于PDF 中文不显,那是因为没有中文字体的 只要把下面代码改一下
并将iTextAsian.jar 引进来就可以了
smallFont = FontFactory.getFont(FontFactory.HELVETICA, 7, Font.NORMAL, new Color(0, 0, 0)); //原代码 smallFont = FontFactory.getFont("STSong-Light","UniGB-UCS2-H", Font.DEFAULTSIZE); //修改后的代码
对于需要过滤Table中的html标签,就需要修改源代码了
其实只要修改 escapeColumnValue(Object value)方法就好,在返回的String加上下段就可以了
//匹配input、font、span和a 四个标签,如果表格还会有其他标签再增就可以了 Pattern p = Pattern.compile("</?[input|font|a|span][^>]*>", Pattern.CASE_INSENSITIVE); Matcher m = p.matcher(returnString); return m.replaceAll("");
将修改后的方法分别在doHeaser和doExport中调用即可
另外由于页面采用了sitemesh装饰器,display的导出也会被加上装饰页的内容,因为displaytag的导出链接是会有 d-16544-e这个参数名,而且是固定的,所以只要在decorators.xml中的<excludes>中加上
<pattern>/*d-16544-e=*</pattern>
就好了.
本文只是记录了怎样解决此项目中问题,此法不一定是最佳解决方案, 如有类似问题可做参考.