2011-01-13 109 views
2

我们在Apache2 webserver后面的Tomcat 6中运行的AXIS2 v1.5.2中实现了POJO Web服务。POJO AXIS2 Web服务请求中的参数未传递给POJO

为了演示目的,我将重点介绍validateUser消息和相应的方法。 所有的消息都以类似的方式表现。

我看过this以及其他一些相关的问题,但他们似乎并没有深入到问题的底部。

当请求发送到服务时,参数将作为空白传递给POJA。

首先WSDL:

<wsdl:definitions xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:ns1="http://org.apache.axis2/xsd" xmlns:ns="http://service.icomet.com" xmlns:wsaw="http://www.w3.org/2006/05/addressing/wsdl" xmlns:http="http://schemas.xmlsoap.org/wsdl/http/" xmlns:ax21="http://util.java/xsd" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/" xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/" xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/" targetNamespace="http://service.icomet.com"> 
<wsdl:types> 
    <xs:schema attributeFormDefault="qualified" elementFormDefault="qualified" targetNamespace="http://util.java/xsd"> 
     <xs:complexType name="Map"> 
      <xs:sequence> 
       <xs:element minOccurs="0" name="empty" type="xs:boolean"/> 
      </xs:sequence> 
     </xs:complexType> 
    </xs:schema> 
    <xs:schema xmlns:ax22="http://util.java/xsd" attributeFormDefault="qualified" elementFormDefault="qualified" targetNamespace="http://service.icomet.com"> 
     <xs:import namespace="http://util.java/xsd"/> 
     <xs:element name="validateUser"> 
       <xs:complexType> 
       <xs:sequence> 
        <xs:element name="user" nillable="true" type="xs:string"/> 
        <xs:element name="userPassword" nillable="true" type="xs:string"/> 
       </xs:sequence> 
      </xs:complexType> 
     </xs:element> 
</xs:schema> 
</wsdl:types> 
<wsdl:message name="validateUserRequest"> 
    <wsdl:part name="parameters" element="ns:validateUser"/> 
</wsdl:message> 

在org.apache.axis2.rpc.receivers.RPCMessageReceiver,org.apache.axis2.rpc.receivers.RPCUtil和的代码一起以下后org.apache.axis2.databinding.utils.BeanUtil 我看到的是使用参数完成我的请求的服务。 所述的OMElement印刷在日志中从:

BeanUtil.deserialize(的OMElement响应, 对象[] javaTypes, ObjectSupplier objectSupplier)看起来像这样: 反序列化(的OMElement响应, 对象[] javaTypes, ObjectSupplier objectSupplier)

看起来是这样的:

<SOAP-ENV:Body xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"> 
<ns:validateUser xmlns:ns="http://service.icomet.com"> 
    <ns:user>test</ns:user> 
    <ns:userPassword>values</ns:userPassword> 
</ns:validateUser> 

通话后得到的OMElement的孩子,看着上面的OMElement的第一个孩子我看到这一点:以上的OMElement返回日志中的多个空行

<ns:validateUser xmlns:ns="http://service.icomet.com"> 
    <ns:user>test</ns:user> 
    <ns:userPassword>values</ns:userPassword> 
</ns:validateUser> 

调用的getText()。

我增加了以下方法:

private static void showElement(OMElement omElement) { 
    System.out.println("onElement class:" + omElement.getClass().getName()); 
    System.out.println("omElement:" + omElement); 
    System.out.println("omElement.getText:" + omElement.getText()); 
    for (Iterator it = omElement.getChildElements(); it.hasNext();) { 
     Object object = it.next(); 
     System.out.println("child class name:" + object.getClass().getName()); 
     System.out.println("child to string:" + object); 

    } 

    for (Iterator it = omElement.getAllAttributes(); it.hasNext();) { 
     OMAttribute object = (OMAttribute) it.next(); 
     System.out.println("OMAttribute:" + object.getAttributeValue()); 
    } 
} 

到BeanUtil类,以便在此的OMElement更好看。此代码返回如下:

onElement class:org.apache.axiom.om.impl.llom.OMElementImpl 
omElement:<ns:validateUser xmlns:ns="http://service.icomet.com"> 
    <ns:user>test</ns:user> 
    <ns:userPassword>values</ns:userPassword> 
</ns:validateUser 

omElement.getText:

child class name:org.apache.axiom.om.impl.llom.OMElementImpl 
child to string:<ns:user xmlns:ns="http://service.icomet.com">test</ns:user> 
child class name:org.apache.axiom.om.impl.llom.OMElementImpl 
child to string:<ns:userPassword xmlns:ns="http://service.icomet.com">values</ns:userPassword> 

所以,我看到的值。他们到达并进入门口可以这么说。但是,由于org.apache.axis2.databinding.typemapping.SimpleTypeMapper.getSimpleTypeObject调用OMElement上的getText并返回一个空字符串,因此RPCUtil.processRequest方法正在返回一个具有空字符串和空对象的对象数组,并且这会传递给POJO。

我知道它的一个很长的问题,但我想我可能还会在前面添加所有这些信息。

回答

1

原来是AXIS2 1.5中的一个bug。

一些细节被发现here

在夜间建立在1/6/2011缺陷被解决。仍在等待确认究竟是如何解决问题的。线程中讨论了一些解决方案。

我使用了最明显的答案,并且自己修补了代码。