今天帮同事调试一个Axis开发的Web Service接口时遇到的诸多问题

EdwardWong 2010-01-05

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客户端缺少了需要的类。

折腾了老久才定位到问题。

相关推荐