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 nb...@touchcorp.com on 2002/09/17 09:22:40 UTC

RPC problems?

Hi,

I'm using what I believe to be the latest version of AXIS on Linux (I
downloaded "xml-axis-rc1-bin.zip" yesterday) and trying to talk to a
Borland SOAP server with 5 different services.  I'm having very weird
problems with it.

I originally started using Apache SOAP, hand-building all the complex
classes I wanted to pass around.  Then I discovered WSDL2Java and used
it to generate all the classes I need.  I implemented one interface
fully to a single service without a hitch.  This wasn't just a 'vanilla'
service, it had plenty of beans being passed around and seemed to work
perfectly.

Then I tried to move onto the next service.

Here is the WSDL of the second service:
http://tims.moveyourselftrailer.com.au:8000/scripts/SackTruck.dll/wsdl/I
SackTruck

I used this snippet of code to try and access the simplest of the ports,
just as I did previously for the other service:

      ISackTruckservice locator = new ISackTruckserviceLocator();
      ISackTruck client = locator.getISackTruckPort();
      Object fees = client.getSackTruckFees();

And got:

org.xml.sax.SAXException: operation description is missing parameter
description!
        at
org.apache.axis.message.RPCHandler.onStartChild(RPCHandler.java:220)
        at
org.apache.axis.encoding.DeserializationContextImpl.startElement(Deseria
lizationContextImpl.java:883)
        at
org.apache.axis.message.SAX2EventRecorder.replay(SAX2EventRecorder.java:
158)
        at
org.apache.axis.message.MessageElement.publishToHandler(MessageElement.j
ava:681)
        at
org.apache.axis.message.RPCElement.deserialize(RPCElement.java:244)
        at
org.apache.axis.message.RPCElement.getParams(RPCElement.java:268)
        at org.apache.axis.client.Call.invoke(Call.java:1862)
        at org.apache.axis.client.Call.invoke(Call.java:1768)
        at org.apache.axis.client.Call.invoke(Call.java:1306)
        at
com.touchcorp.soap.isacktruck.ISackTruckbindingStub.getSackTruckFees(ISa
ckTruckbindingStub.java:228)
        at
com.touchcorp.remote.party.ISackTruckService.getSackTruckFees(ISackTruck
Service.java:96)
        at
com.touchcorp.remote.party.ISackTruckService.main(ISackTruckService.java
:133)
[ERROR] Call - -Exception: <org.xml.sax.SAXException: operation
description is missing parameter description!>
Exception in thread "main" AxisFault
 faultCode: {http://xml.apache.org/axis/}Server.userException
 faultString: org.xml.sax.SAXException: operation description is missing
parameter description!
 faultActor: null
 faultDetail:
        stackTrace: org.xml.sax.SAXException: operation description is
missing parameter description!
        at
org.apache.axis.message.RPCHandler.onStartChild(RPCHandler.java:220)
        at
org.apache.axis.encoding.DeserializationContextImpl.startElement(Deseria
lizationContextImpl.java:883)
        at
org.apache.axis.message.SAX2EventRecorder.replay(SAX2EventRecorder.java:
158)
        at
org.apache.axis.message.MessageElement.publishToHandler(MessageElement.j
ava:681)
        at
org.apache.axis.message.RPCElement.deserialize(RPCElement.java:244)
        at
org.apache.axis.message.RPCElement.getParams(RPCElement.java:268)
        at org.apache.axis.client.Call.invoke(Call.java:1862)
        at org.apache.axis.client.Call.invoke(Call.java:1768)
        at org.apache.axis.client.Call.invoke(Call.java:1306)
        at
com.touchcorp.soap.isacktruck.ISackTruckbindingStub.getSackTruckFees(ISa
ckTruckbindingStub.java:228)
        at
com.touchcorp.remote.party.ISackTruckService.getSackTruckFees(ISackTruck
Service.java:96)
        at
com.touchcorp.remote.party.ISackTruckService.main(ISackTruckService.java
:133)

org.xml.sax.SAXException: operation description is missing parameter
description!
org.xml.sax.SAXException: operation description is missing parameter
description!
        at
org.apache.axis.message.RPCHandler.onStartChild(RPCHandler.java:220)
        at
org.apache.axis.encoding.DeserializationContextImpl.startElement(Deseria
lizationContextImpl.java:883)
        at
org.apache.axis.message.SAX2EventRecorder.replay(SAX2EventRecorder.java:
158)
        at
org.apache.axis.message.MessageElement.publishToHandler(MessageElement.j
ava:681)
        at
org.apache.axis.message.RPCElement.deserialize(RPCElement.java:244)
        at
org.apache.axis.message.RPCElement.getParams(RPCElement.java:268)
        at org.apache.axis.client.Call.invoke(Call.java:1862)
        at org.apache.axis.client.Call.invoke(Call.java:1768)
        at org.apache.axis.client.Call.invoke(Call.java:1306)
        at
com.touchcorp.soap.isacktruck.ISackTruckbindingStub.getSackTruckFees(ISa
ckTruckbindingStub.java:228)
        at
com.touchcorp.remote.party.ISackTruckService.getSackTruckFees(ISackTruck
Service.java:96)
        at
com.touchcorp.remote.party.ISackTruckService.main(ISackTruckService.java
:133)


But, if I go back and use Apache SOAP directly, everything seems to work
just fine.  I am *not* using an operation style of "rpc" when I call via
SOAP directly.  My code looks more like this:

      URL url = new URL(locator.getISackTruckPortAddress());
      String uri = "urn:uSackTruckFee";
      String method = "getSackTruckFees";
      Class type =
com.touchcorp.soap.isacktruck.TSackTruckFeeInfo.class;
      Vector args = new Vector();

      // get short version of type class name
      String typeName = type.getName();
      int index = typeName.lastIndexOf(".");
      if (index > 0)
          typeName = typeName.substring(index+1);

      // set up bean mappings
      SOAPMappingRegistry registry = new SOAPMappingRegistry();
      BeanSerializer serializer = new BeanSerializer();
      registry.mapTypes(Constants.NS_URI_SOAP_ENC, new QName(uri,
typeName), type, serializer, serializer);

      // build the call
      Call call = new Call();
      call.setSOAPMappingRegistry(registry);
      call.setTargetObjectURI(uri);
      call.setMethodName(method);
      call.setEncodingStyleURI(Constants.NS_URI_SOAP_ENC);
      call.setParams(args);

      // make the call
      Response response = call.invoke(url, "");

Help!

I have attached some of the relevant WSDL2Java-generated code below.
Any assistance at all would be appreciated greatly.  This is the most
common error I am seeing with AXIS, and I get it with almost every
method I try, but I am also getting many other equally strange errors to
do with serializers, out-of-range errors and other things.  One at a
time.

Regards,

Neil Brennan

------------------------------------------------------------------------
------------------------------------------------------------------------
------------

============================
from ISackTruckbindingStub.java:
============================

    public com.touchcorp.soap.isacktruck.TSackTruckFeeInfo
getSackTruckFees() throws java.rmi.RemoteException {
        if (super.cachedEndpoint == null) {
            throw new org.apache.axis.NoEndPointException();
        }
        org.apache.axis.client.Call _call = createCall();
        _call.setReturnType(new
javax.xml.namespace.QName("urn:uSackTruckFee", "TSackTruckFeeInfo"),
com.touchcorp.soap.isacktruck.TSackTruckFeeInfo.class);
        _call.setUseSOAPAction(true);
 
_call.setSOAPActionURI("urn:uSackTruckIntf-ISackTruck#getSackTruckFees")
;
        _call.setOperationStyle("rpc");
        _call.setOperationName(new
javax.xml.namespace.QName("urn:uSackTruckIntf-ISackTruck",
"getSackTruckFees"));

        java.lang.Object _resp = _call.invoke(new java.lang.Object[]
{});

        if (_resp instanceof java.rmi.RemoteException) {
            throw (java.rmi.RemoteException)_resp;
        }
        else {
            try {
                return (com.touchcorp.soap.isacktruck.TSackTruckFeeInfo)
_resp;
            } catch (java.lang.Exception _exception) {
                return (com.touchcorp.soap.isacktruck.TSackTruckFeeInfo)
org.apache.axis.utils.JavaUtils.convert(_resp,
com.touchcorp.soap.isacktruck.TSackTruckFeeInfo.class);
            }
        }
    }

============================
from TSackTruckFeeInfo.java:
============================

/**
 * TSackTruckFeeInfo.java
 *
 * This file was auto-generated from WSDL
 * by the Apache Axis WSDL2Java emitter.
 */

package com.touchcorp.soap.isacktruck;

public class TSackTruckFeeInfo  implements java.io.Serializable {
    private double deposit;
    private double hireFee;

    public TSackTruckFeeInfo() {
    }

    public double getDeposit() {
        return deposit;
    }

    public void setDeposit(double deposit) {
        this.deposit = deposit;
    }

    public double getHireFee() {
        return hireFee;
    }

    public void setHireFee(double hireFee) {
        this.hireFee = hireFee;
    }

    private java.lang.Object __equalsCalc = null;
    public synchronized boolean equals(java.lang.Object obj) {
        if (!(obj instanceof TSackTruckFeeInfo)) return false;
        TSackTruckFeeInfo other = (TSackTruckFeeInfo) obj;
        if (obj == null) return false;
        if (this == obj) return true;
        if (__equalsCalc != null) {
            return (__equalsCalc == obj);
        }
        __equalsCalc = obj;
        boolean _equals;
        _equals = true && 
            deposit == other.getDeposit() &&
            hireFee == other.getHireFee();
        __equalsCalc = null;
        return _equals;
    }

    private boolean __hashCodeCalc = false;
    public synchronized int hashCode() {
        if (__hashCodeCalc) {
            return 0;
        }
        __hashCodeCalc = true;
        int _hashCode = 1;
        _hashCode += new Double(getDeposit()).hashCode();
        _hashCode += new Double(getHireFee()).hashCode();
        __hashCodeCalc = false;
        return _hashCode;
    }

    // Type metadata
    private static org.apache.axis.description.TypeDesc typeDesc =
        new
org.apache.axis.description.TypeDesc(TSackTruckFeeInfo.class);

    static {
        org.apache.axis.description.FieldDesc field = new
org.apache.axis.description.ElementDesc();
        field.setFieldName("deposit");
        field.setXmlName(new javax.xml.namespace.QName("", "Deposit"));
        typeDesc.addFieldDesc(field);
        field = new org.apache.axis.description.ElementDesc();
        field.setFieldName("hireFee");
        field.setXmlName(new javax.xml.namespace.QName("", "HireFee"));
        typeDesc.addFieldDesc(field);
    };

    /**
     * Return type metadata object
     */
    public static org.apache.axis.description.TypeDesc getTypeDesc() {
        return typeDesc;
    }

    /**
     * Get Custom Serializer
     */
    public static org.apache.axis.encoding.Serializer getSerializer(
           java.lang.String mechType, 
           java.lang.Class _javaType,  
           javax.xml.namespace.QName _xmlType) {
        return 
          new  org.apache.axis.encoding.ser.BeanSerializer(
            _javaType, _xmlType, typeDesc);
    }

    /**
     * Get Custom Deserializer
     */
    public static org.apache.axis.encoding.Deserializer getDeserializer(
           java.lang.String mechType, 
           java.lang.Class _javaType,  
           javax.xml.namespace.QName _xmlType) {
        return 
          new  org.apache.axis.encoding.ser.BeanDeserializer(
            _javaType, _xmlType, typeDesc);
    }

}