牧灵泉的崖巢 2014-04-14
最近在使用HighCharts进行图标统计分析的时候,客户要求对生成的统计结果图可以导出到Excel查看。
通过查看相关资料,在得知HighCharts通过SVG生成图标文件信息,那思路就基本确定了,将提交上来的SVG表述字符串转换成图片并写入Excel文件,并将Excel文件转换成流的形式返回到前端进行下载输出。查找Apache下的开源库batik可以完成SVG格式转换为图片的功能,开始着手进行代码开始。
在Maven中引入batik相关开发包,如下:
<dependency> <groupId>batik</groupId> <artifactId>batik-transcoder</artifactId> <version>1.6-1</version> </dependency>
利用batik的jar包,转换SVG需要生成的图片类型,生成输出流,写入Excel。Eclipse下编译运行,貌似一切顺利。 程序测试通过后,发布,在服务器上部署。
但问题来了,在部署到服务器上,一测试,在下载统计结果的时候,报错。(,什么情况!!心中千万只XX马奔腾而来。)本地测试OK的,部署怎么出问题了,部署的文件有问题?服务器环境不一致?
查看错误日志,提示,写道
少jar包?但通过比对本地和服务器上的jar包,没问题。网上找了一圈,没发现问题。最后没辙,既然少jar,那就补上。下载apache的crimson包,再一跑,继续报错,“提示用于解析xsl的版本过低,升级JDK到1.5什么的”。彻底晕菜,我用的JDK1.7啊。
整理一下思路,搜了一把crimson,结果还真发现了问题。
原来在解析XML文件的时候,crimson作为apache的早期版本,和现在JAXP采用的XML解析器Xerces并不通用。而我在引入的batik版本中,需要引用crimson作为xml解析器,显然引用的batik版本不正确。
最后通过查找正确的batik版本地址,导入项目,部署,终于拨开乌云见晴天了,服务器正常下载包含图片的Excel文件。
<dependency> <groupId>org.apache.xmlgraphics</groupId> <artifactId>batik-codec</artifactId> <version>1.7</version> </dependency>虽然部署成功,但还有一个问题没有解决。为什么eclipse通过jetty运行正常,但部署到tomcat就出现问题?可能是jetty和tomcat之间差异的问题吧,此问题留待以后继续解决。