一、jar包冲突问题解决
1、问题描述:
引入新外围项目的jar后,在本地tomcat运行正常,但是在was服务器调用httpclient.jar中方法提示异常(该异常为系统异常,Java代码的try catch 无法捕获,was的sysout.log中才可以查看)。
2、问题原因:
项目中的commons-httpclient.jar与httpclient.jar系类的http包存在冲突(网上有的说法是项目中的jar和was自带的存在冲突,个人不认可该种说法),Tomcat的加载class顺序与was不同,所以未出问题。
3、解决方案:
通过建立共享库,改变was加载顺序,优先加载httpclient.jar系类jar包。共享库建立步骤如下。
(1)将需要共享的jar放到服务器有访问权限的文件夹下。
(2)打开was控制台,“环境”—“共享库”—“新建”,新建一个共享库,名称任意,类路径为上一步jar在服务器的存放路径,按如图操作后保存设置。
(3)先删除原server级别下的配置。(上个版本配置共享库时添加,该块内容可要可不要,建议删除。)
(4)打开“应用程序“—”应用程序类型“—”webSphere企业应用程序“,先停止STM项目服务,再点击STM项目进入,点击”引用共享库“,并且将本应用的类加载顺序,也改为本地优先。
二、was服务类加载顺序
1、未引用共享库时
2、Web程序引用共享库时
3、模块引用共享库时
参考:
1、websphere7.0 创建共享库,引用共享库
2、websphere7.0 jar包冲突解决办法,类加载顺序
未解决疑问:
通过打印调用http类的加载链,发现在Tomcat和was是一致的,这样就无法用以上内容解释,但是通过共享库又解决了问题,不解。