最近公司的项目都在从WS上面往JBoss上面迁移,由于之前的项目很多技术都依赖WS,所以改动很大。近期我负责的就是WebService的模块的改动。新的项目完全脱离WS发布在Tomcat上面完全没有问题,可是一放到JBoss上面问题出现一大堆。
javax.servlet.ServletException: java.lang.LinkageError: loader constraint violation: loader (instance of org/jboss/web/tomcat/service/WebCtxLoader$ENCLoader) previously initiated loading for a different type with name "javax/xml/soap/AttachmentPart"
org.apache.struts.actions.DispatchAction.dispatchMethod(DispatchAction.java:298)
org.apache.struts.actions.DispatchAction.execute(DispatchAction.java:194)
org.apache.struts.action.RequestProcessor.processActionPerform(RequestProcessor.java:419)
org.apache.struts.action.RequestProcessor.process(RequestProcessor.java:224)
org.apache.struts.action.ActionServlet.process(ActionServlet.java:1194)
org.apache.struts.action.ActionServlet.doGet(ActionServlet.java:414)
javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
com.zhx.zhb.application.common.pageFilter.RequestEncodeConversionFilter.doFilter(RequestEncodeConversionFilter.java:20)
org.jboss.web.tomcat.filters.ReplyHeaderFilter.doFilter(ReplyHeaderFilter.java:96)
看上面是JBoss和项目中某个类发生了冲突,我查找这个类发现JDK1.6、JavaEE5.0和项目中的一个WS的jar包中存在这个类,我先将jar包删除了,但是发现项目还是有问题,随后我将JavaEE和JDK中的类也删除了,项目还是报上面的错误,我又将JDK和JavaEE中删除的类复原,将JBoss中的冲突类删除,发现JBoss无法正常启动。没有办法,上网查了很多的资料,很多都说JDK和JBoss里面的jar包冲突,需要把JBoss中的jar放到jre的bin的endorsed文件夹中,可是还是不好使,整整困扰了我两天,真的到崩溃的边缘了。
后来忽然想为什么将JDK和JavaEE还有WS的jar包删除了项目还是会报这个问题,难道其他地方还有这个类,我查找了整个项目发现没有了,那是为什么,忽然之间想到是不是删除了jar包之后,项目没有重新编译呢,为了测试自己的猜想,我手动重新编译了一下项目,发现真的没问题了。原因就是WS的jar包删除之后,Myeclipse因为某些原因没有自动重新编译才造成的。和JDK、JavaEE里面的类没有关系。
所以,小伙伴们儿,如果你的项目出现了问题,而你也在崩溃的边缘了,不妨试一下我的方法重新编译一下项目,可能就豁然开朗了,问题很有可能就是开发工具因为某些原因在你重改项目的时候没有重新编译。
图 1.0
图 2.0