displaytag 导出中文乱码和去掉HTML标签的解决方法

最近做的项目中用到了displaytagdisplaytag还是一个相当不错的分页标签,功能比较强大,最重要的是开源的。项目中部分列表需要实现导出excelpdf。直接采用displaytag的导出,发现有两个问题,第一就是中文问题,excelcsv中都会有乱码,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("");

 

 

 

 

将修改后的方法分别在doHeaserdoExport中调用即可

 

 

另外由于页面采用了sitemesh装饰器,display的导出也会被加上装饰页的内容,因为displaytag的导出链接是会有 d-16544-e这个参数名,而且是固定的,所以只要在decorators.xml中的<excludes>中加上

<pattern>/*d-16544-e=*</pattern>

 

 就好了.

 

 

 

本文只是记录了怎样解决此项目中问题,此法不一定是最佳解决方案, 如有类似问题可做参考.

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值