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

1. 首先是容器兼容的J2EE版本问题
   新建的工程指定的是J2EE1.4版本,在web.xml描述符中也指定了Web Application 2.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中声明的方法跟服务器上的不一致,如少掉throws BssException,调整一致后仍然有问题。

   后来再仔细观察下控制台的日志,发现调用EJB的时候确实抛出了异常: EJB home [............] has no no-arg create() method
   问题终于定位了,此异常是由于EJB客户端缺少了需要的类。

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

你可能感兴趣的:(spring,Web,xml,webservice,ejb)