开头需要说明的是,这个移植过程中,是从windows平台移植到IBM的Aix平台上进行的.中间遇到了一些问题,上网这方面的资料不多,现归纳我移植过程中碰到并解决的问题.希望对大家有帮助.
1 问题:在weblogic上发布工程时,出现 java.lang.StringIndexOutOfBoundsException: String index out of range: -1
原因:工程中使用的spring包的MANIFEST.MF文件太大,导致weblogic加载时出现字符串越界。
解决:解压包,修改文件的内容,即去除掉无用的说明信息,保证在1k大小左右,再打包放入工程,发布工程就没问题了.
这个也主要是对weblogic8.1而言,更高版本的可能已经解决了这个bug.
2 问题:项目中的功能模块,导出sql文件时,出现异常页面的数据。
原因:weblogic8.1目前不支持servlet2.4,而在生成sql文件时,我使用是reponse的输出流写数据,中间使用到了设置编码格 式setCharacterEncoding方法,而这个方法在这个版本之后才有的。
解决:把tomcat下可以使用responset的setCharacterEncoding("UTF-8")方法去除掉,并且必须把用于输出流的子节数组 先转码为UTF-8,确保输出内容不会出现乱码。还有一种就是 升级weblogic到9.0版本,从而支持servlet2.4。
3 问题:工程中使用到的导出报表模块,当运行到报表填充数据JasperFillManager.fillReport方法时,出现异常。
原因:在fillReport的方法中使用到了java.awt包中的 GraphicsEnvironment.getLocalGraphicsEnvironment().getAvailableFontFamilyNames()的方法,这个是用来
取字体信息的,取的过程出现异常。
解决:在weblogic启动参数中加入-Djava.awt.headless=true,使其使用到字体信息时能够得到字体名字列表信息。
归结起来这个参数其实是告诉jvm,目前系统中需要用到字体信息.
4 问题:导出报表文件,出现异常的数据
原因:response的OutputStream输出流没有清空缓存。
解决:导出报表文件时,使用的是OutputStream输出流,tomacat默认会清空缓存,weblogic则不会
所以在调用完报表的exportReport()函数后,还必须把OutputStream输出流flush一下。这里需要注意的是我使用的报表
组件是JasperReport报表组件.看过原代码后,其实在传入输出流,调用exportReport()生成excel时,并没有在内部flush数据.所以我们必须自己在外面flush缓冲数据.
5 问题:输出页面时出现Error 500--Internal Server Error:weblogic.utils.ParsingException: nested TokenStreamException:antlr.TokenStreamIOException异常.
原因:页面和weblogic设置的编码格式不一样。
解决:保证weblogic启动参数的编码和所返回的页面编码一致。比如页面中是<%@ page contentType="text/html; charset=UTF-8" %>
则启动参数则加入 -Dibm.system.encoding=UTF-8 -Dfile.encoding=UTF-8。
总的来说在,所有涉及的编码格式时,项目中要统一使用编码格式,包括系统配置,应用服务器配置,页面配置等,可以有效避免编码转换出现的乱码等问题.