You are viewing a plain text version of this content. The canonical link for it is here.
Posted to java-user@axis.apache.org by "Urban, John" <Jo...@Williams.com> on 2006/11/13 20:46:14 UTC
Problem calling .NET WebService from Axis2 Java Client
I generated the java code from the wsdl using wsdl2java in the axis2
distribution. I got everything to compile.
I am able to get the call the .net 2.0 web service with the code and get
a response back(I even stepped through the VS debugger):
[javacode]
InventoryServicesStub stub = new InventoryServicesStub(null,
"http://localhost:2067/NGLPTOServices_VS/InventoryServices.asmx/Ping");
InventoryServicesStub.Ping ping = new InventoryServicesStub.Ping();
InventoryServicesStub.PingResponse response = stub.Ping(ping);
String results = response.getPingResult();
System.out.println("Response : " + results);
[/javacode]
I can see it execute in Visual Studio debugger and return. When control
comes back to my eclipse debugger, I get the following AxisFault:
"First Element must contain the local name, Envelope"
How do I fix this?
Here is my WSDL:
[code]
<?xml version="1.0" encoding="utf-8"?>
<wsdl:definitions xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
xmlns:tm="http://microsoft.com/wsdl/mime/textMatching/"
xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/"
xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/"
xmlns:tns="http://tempuri.org/"
xmlns:s="http://www.w3.org/2001/XMLSchema"
xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/"
xmlns:http="http://schemas.xmlsoap.org/wsdl/http/"
targetNamespace="http://tempuri.org/"
xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/">
<wsdl:types>
<s:schema elementFormDefault="qualified"
targetNamespace="http://tempuri.org/">
<s:element name="Ping">
<s:complexType />
</s:element>
<s:element name="PingResponse">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="PingResult"
type="s:string" />
</s:sequence>
</s:complexType>
</s:element>
<s:element name="GetInventoryReport">
<s:complexType />
</s:element>
<s:element name="GetInventoryReportResponse">
<s:complexType>
<s:sequence>
<s:element minOccurs="0" maxOccurs="1"
name="GetInventoryReportResult" type="tns:Results" />
</s:sequence>
</s:complexType>
</s:element>
<s:complexType name="Results">
<s:sequence>
<s:element minOccurs="1" maxOccurs="1" name="timestamp"
type="s:dateTime" />
<s:element minOccurs="0" maxOccurs="1" name="status"
type="s:string" />
<s:element minOccurs="0" maxOccurs="1" name="message"
type="s:string" />
<s:element minOccurs="0" maxOccurs="1" name="report"
type="tns:ArrayOfInventoryReport" />
</s:sequence>
</s:complexType>
<s:complexType name="ArrayOfInventoryReport">
<s:sequence>
<s:element minOccurs="0" maxOccurs="unbounded"
name="InventoryReport" nillable="true" type="tns:InventoryReport" />
</s:sequence>
</s:complexType>
<s:complexType name="InventoryReport">
<s:sequence>
<s:element minOccurs="0" maxOccurs="1" name="CONTRACT"
type="s:string" />
<s:element minOccurs="0" maxOccurs="1" name="PRODUCT_NAME"
type="s:string" />
<s:element minOccurs="0" maxOccurs="1" name="VOLUME_TYPE"
type="s:string" />
<s:element minOccurs="0" maxOccurs="1" name="MV_HEADER_DATE"
type="s:string" />
<s:element minOccurs="0" maxOccurs="1" name="TICKET"
type="s:string" />
<s:element minOccurs="1" maxOccurs="1" name="BARRELS"
type="s:double" />
<s:element minOccurs="1" maxOccurs="1" name="PRODUCT_ORDER"
type="s:int" />
<s:element minOccurs="1" maxOccurs="1" name="SORT_ORDER"
type="s:int" />
</s:sequence>
</s:complexType>
</s:schema>
</wsdl:types>
<wsdl:message name="PingSoapIn">
<wsdl:part name="parameters" element="tns:Ping" />
</wsdl:message>
<wsdl:message name="PingSoapOut">
<wsdl:part name="parameters" element="tns:PingResponse" />
</wsdl:message>
<wsdl:message name="GetInventoryReportSoapIn">
<wsdl:part name="parameters" element="tns:GetInventoryReport" />
</wsdl:message>
<wsdl:message name="GetInventoryReportSoapOut">
<wsdl:part name="parameters"
element="tns:GetInventoryReportResponse" />
</wsdl:message>
<wsdl:portType name="InventoryServicesSoap">
<wsdl:operation name="Ping">
<wsdl:input message="tns:PingSoapIn" />
<wsdl:output message="tns:PingSoapOut" />
</wsdl:operation>
<wsdl:operation name="GetInventoryReport">
<wsdl:input message="tns:GetInventoryReportSoapIn" />
<wsdl:output message="tns:GetInventoryReportSoapOut" />
</wsdl:operation>
</wsdl:portType>
<wsdl:binding name="InventoryServicesSoap"
type="tns:InventoryServicesSoap">
<soap:binding transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="Ping">
<soap:operation soapAction="http://tempuri.org/Ping"
style="document" />
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="GetInventoryReport">
<soap:operation
soapAction="http://tempuri.org/GetInventoryReport" style="document" />
<wsdl:input>
<soap:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:binding name="InventoryServicesSoap12"
type="tns:InventoryServicesSoap">
<soap12:binding transport="http://schemas.xmlsoap.org/soap/http" />
<wsdl:operation name="Ping">
<soap12:operation soapAction="http://tempuri.org/Ping"
style="document" />
<wsdl:input>
<soap12:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap12:body use="literal" />
</wsdl:output>
</wsdl:operation>
<wsdl:operation name="GetInventoryReport">
<soap12:operation
soapAction="http://tempuri.org/GetInventoryReport" style="document" />
<wsdl:input>
<soap12:body use="literal" />
</wsdl:input>
<wsdl:output>
<soap12:body use="literal" />
</wsdl:output>
</wsdl:operation>
</wsdl:binding>
<wsdl:service name="InventoryServices">
<wsdl:port name="InventoryServicesSoap"
binding="tns:InventoryServicesSoap">
<soap:address
location="http://localhost:2067/NGLPTOServices_VS/InventoryServices.asmx
"/>
</wsdl:port>
<wsdl:port name="InventoryServicesSoap12"
binding="tns:InventoryServicesSoap12">
<soap12:address
location="http://localhost:2067/NGLPTOServices_VS/InventoryServices.asmx
"/>
</wsdl:port>
</wsdl:service>
</wsdl:definitions>
[/code]
Re: Problem calling .NET WebService from Axis2 Java Client
Posted by Paul Fremantle <pz...@gmail.com>.
The easiest way to debug this will be to use TCPMON or some other
tracer to see what the response looks like.
Paul
On 11/13/06, Urban, John <Jo...@williams.com> wrote:
>
>
>
>
> I generated the java code from the wsdl using wsdl2java in the axis2
> distribution. I got everything to compile.
>
>
>
> I am able to get the call the .net 2.0 web service with the code and get a
> response back(I even stepped through the VS debugger):
>
> [javacode]
> InventoryServicesStub stub = new InventoryServicesStub(null,
> "http://localhost:2067/NGLPTOServices_VS/InventoryServices.asmx/Ping");
> InventoryServicesStub.Ping ping = new InventoryServicesStub.Ping();
>
> InventoryServicesStub.PingResponse response =
> stub.Ping(ping);
>
> String results = response.getPingResult();
> System.out.println("Response : " + results);
> [/javacode]
>
> I can see it execute in Visual Studio debugger and return. When control
> comes back to my eclipse debugger, I get the following AxisFault:
>
> "First Element must contain the local name, Envelope"
>
> How do I fix this?
>
> Here is my WSDL:
>
> [code]
> <?xml version="1.0" encoding="utf-8"?>
> <wsdl:definitions
> xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
> xmlns:tm="http://microsoft.com/wsdl/mime/textMatching/"
> xmlns:soapenc="http://schemas.xmlsoap.org/soap/encoding/"
> xmlns:mime="http://schemas.xmlsoap.org/wsdl/mime/"
> xmlns:tns="http://tempuri.org/"
> xmlns:s="http://www.w3.org/2001/XMLSchema"
> xmlns:soap12="http://schemas.xmlsoap.org/wsdl/soap12/"
> xmlns:http="http://schemas.xmlsoap.org/wsdl/http/"
> targetNamespace="http://tempuri.org/"
> xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/">
> <wsdl:types>
> <s:schema elementFormDefault="qualified"
> targetNamespace="http://tempuri.org/">
> <s:element name="Ping">
> <s:complexType />
> </s:element>
> <s:element name="PingResponse">
> <s:complexType>
> <s:sequence>
> <s:element minOccurs="0" maxOccurs="1" name="PingResult"
> type="s:string" />
> </s:sequence>
> </s:complexType>
> </s:element>
> <s:element name="GetInventoryReport">
> <s:complexType />
> </s:element>
> <s:element name="GetInventoryReportResponse">
> <s:complexType>
> <s:sequence>
> <s:element minOccurs="0" maxOccurs="1"
> name="GetInventoryReportResult" type="tns:Results" />
> </s:sequence>
> </s:complexType>
> </s:element>
> <s:complexType name="Results">
> <s:sequence>
> <s:element minOccurs="1" maxOccurs="1" name="timestamp"
> type="s:dateTime" />
> <s:element minOccurs="0" maxOccurs="1" name="status"
> type="s:string" />
> <s:element minOccurs="0" maxOccurs="1" name="message"
> type="s:string" />
> <s:element minOccurs="0" maxOccurs="1" name="report"
> type="tns:ArrayOfInventoryReport" />
> </s:sequence>
> </s:complexType>
> <s:complexType name="ArrayOfInventoryReport">
> <s:sequence>
> <s:element minOccurs="0" maxOccurs="unbounded"
> name="InventoryReport" nillable="true" type="tns:InventoryReport" />
> </s:sequence>
> </s:complexType>
> <s:complexType name="InventoryReport">
> <s:sequence>
> <s:element minOccurs="0" maxOccurs="1" name="CONTRACT"
> type="s:string" />
> <s:element minOccurs="0" maxOccurs="1" name="PRODUCT_NAME"
> type="s:string" />
> <s:element minOccurs="0" maxOccurs="1" name="VOLUME_TYPE"
> type="s:string" />
> <s:element minOccurs="0" maxOccurs="1" name="MV_HEADER_DATE"
> type="s:string" />
> <s:element minOccurs="0" maxOccurs="1" name="TICKET"
> type="s:string" />
> <s:element minOccurs="1" maxOccurs="1" name="BARRELS"
> type="s:double" />
> <s:element minOccurs="1" maxOccurs="1" name="PRODUCT_ORDER"
> type="s:int" />
> <s:element minOccurs="1" maxOccurs="1" name="SORT_ORDER"
> type="s:int" />
> </s:sequence>
> </s:complexType>
> </s:schema>
> </wsdl:types>
> <wsdl:message name="PingSoapIn">
> <wsdl:part name="parameters" element="tns:Ping" />
> </wsdl:message>
> <wsdl:message name="PingSoapOut">
> <wsdl:part name="parameters" element="tns:PingResponse" />
> </wsdl:message>
> <wsdl:message name="GetInventoryReportSoapIn">
> <wsdl:part name="parameters"
> element="tns:GetInventoryReport" />
> </wsdl:message>
> <wsdl:message name="GetInventoryReportSoapOut">
> <wsdl:part name="parameters"
> element="tns:GetInventoryReportResponse" />
> </wsdl:message>
> <wsdl:portType name="InventoryServicesSoap">
> <wsdl:operation name="Ping">
> <wsdl:input message="tns:PingSoapIn" />
> <wsdl:output message="tns:PingSoapOut" />
> </wsdl:operation>
> <wsdl:operation name="GetInventoryReport">
> <wsdl:input message="tns:GetInventoryReportSoapIn"
> />
> <wsdl:output message="tns:GetInventoryReportSoapOut"
> />
> </wsdl:operation>
> </wsdl:portType>
> <wsdl:binding name="InventoryServicesSoap"
> type="tns:InventoryServicesSoap">
> <soap:binding
> transport="http://schemas.xmlsoap.org/soap/http" />
> <wsdl:operation name="Ping">
> <soap:operation soapAction="http://tempuri.org/Ping"
> style="document" />
> <wsdl:input>
> <soap:body use="literal" />
> </wsdl:input>
> <wsdl:output>
> <soap:body use="literal" />
> </wsdl:output>
> </wsdl:operation>
> <wsdl:operation name="GetInventoryReport">
> <soap:operation
> soapAction="http://tempuri.org/GetInventoryReport"
> style="document" />
> <wsdl:input>
> <soap:body use="literal" />
> </wsdl:input>
> <wsdl:output>
> <soap:body use="literal" />
> </wsdl:output>
> </wsdl:operation>
> </wsdl:binding>
> <wsdl:binding name="InventoryServicesSoap12"
> type="tns:InventoryServicesSoap">
> <soap12:binding
> transport="http://schemas.xmlsoap.org/soap/http" />
> <wsdl:operation name="Ping">
> <soap12:operation soapAction="http://tempuri.org/Ping"
> style="document" />
> <wsdl:input>
> <soap12:body use="literal" />
> </wsdl:input>
> <wsdl:output>
> <soap12:body use="literal" />
> </wsdl:output>
> </wsdl:operation>
> <wsdl:operation name="GetInventoryReport">
> <soap12:operation
> soapAction="http://tempuri.org/GetInventoryReport"
> style="document" />
> <wsdl:input>
> <soap12:body use="literal" />
> </wsdl:input>
> <wsdl:output>
> <soap12:body use="literal" />
> </wsdl:output>
> </wsdl:operation>
> </wsdl:binding>
> <wsdl:service name="InventoryServices">
> <wsdl:port name="InventoryServicesSoap"
> binding="tns:InventoryServicesSoap">
> <soap:address
> location="http://localhost:2067/NGLPTOServices_VS/InventoryServices.asmx"/>
> </wsdl:port>
> <wsdl:port name="InventoryServicesSoap12"
> binding="tns:InventoryServicesSoap12">
> <soap12:address
> location="http://localhost:2067/NGLPTOServices_VS/InventoryServices.asmx"/>
> </wsdl:port>
> </wsdl:service>
> </wsdl:definitions>
> [/code]
>
>
--
Paul Fremantle
VP/Technology, WSO2 and OASIS WS-RX TC Co-chair
http://bloglines.com/blog/paulfremantle
paul@wso2.com
"Oxygenating the Web Service Platform", www.wso2.com
---------------------------------------------------------------------
To unsubscribe, e-mail: axis-user-unsubscribe@ws.apache.org
For additional commands, e-mail: axis-user-help@ws.apache.org