今天帮同事调试一个Axis开发的Web Service接口时遇到的诸多问题
1.首先是容器兼容的J2EE版本问题
新建的工程指定的是J2EE1.4版本,在web.xml描述符中也指定了WebApplication2.4
然后部署到weblogic8.1的时候直接报错了。
解决方法是:
weblogic8.1实现的是J2EE1.3的规范,应该调增为此版本,web.xml也应相应调整.
2.类路径下Spring相关类包有两份,一份是单独各模块包,一份是all-in-one
3.后来这些调整过来后,用WSDL2Java生成的客户端一直报如下错误:
AxisFault faultCode: {http://schemas.xmlsoap.org/soap/envelope/}Server.userException faultSubcode: faultString: faultActor: faultNode: faultDetail:
却未注意到服务器端抛任何异常,开始怀疑是XML解析的类包冲突问题,折腾了半天,错误仍然存在。
后来就干脆调整了webservice接口的入参,把其中一个Map换成了String类型,再次调用发现竟然可以。于是又开始怀疑是否是因为wsdl4j版本过低问题,导致不支持Map入参的解析,换成最新的wsdl4j包问题依然存在,且生成的客户端也同样是用相同的类包,排除了wsdl4j问题
比较了下Map入参和String入参具体实现代码,发现一个有调用EJB,一个未调用直接返回,于是问题锁定在EJB的调用上。
此用到spring的SimpleRemoteStatelessSessionProxyFactoryBean访问EJB,开始以为是businessInterface中声明的方法跟服务器上的不一致,如少掉throwsBssException,调整一致后仍然有问题。
后来再仔细观察下控制台的日志,发现调用EJB的时候确实抛出了异常:EJBhome[............]hasnono-argcreate()method
问题终于定位了,此异常是由于EJB客户端缺少了需要的类。
折腾了老久才定位到问题。