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 "Heitzeg, Bill" <bi...@sabre.com> on 2004/01/15 19:22:38 UTC
Mapping exceptions to faults using Doc Literal
I'm am trying to map a java exception to a SOAP fault using a Doc Literal structure. I'm generating the WSDL from my Java Code. I'm having a very easy time with complex data types, but I can't figure out what I need to do to map an exception to a fault. I think I've listed all the relevant information below, but let me know if there is something missing.
thanks,
Bill Heitzeg
My WebService Class looks like:
package com.sabre.cruise.webservices.prototype;
/**
The <code>ClassName</code> class is used
@author <a href="mailto: bill.heitzeg.ctr@sabre.com">Bill Heitzeg</a>
@version 1.0
*/
public class BillWebService
{
public ReallyComplexDataType HelloWorld( ComplexDataType myComplexDataType) throws BillWebServiceFault
{
String inputString = myComplexDataType.getString();
if ( inputString.compareTo("XXXX")==0)
throw new BillWebServiceFault("A Sample Exception");
ComplexDataType nestedDataType = new ComplexDataType();
nestedDataType.setString("Nested Data Type String");
ReallyComplexDataType reallyComplexDataType = new ReallyComplexDataType();
reallyComplexDataType.setReturnMessage("Hello " + myComplexDataType.getString() + " welcome to Complex Data Types!");
reallyComplexDataType.setNestedDataType( nestedDataType );
return reallyComplexDataType;
}
}
My Exception class looks like:
package com.sabre.cruise.webservices.prototype;
/**
* @author sg910604
*
* To change the template for this generated type comment go to
* Window>Preferences>Java>Code Generation>Code and Comments
*/
public class BillWebServiceFault extends Exception
{
/**
*
*/
public BillWebServiceFault()
{
super();
// TODO Auto-generated constructor stub
}
/**
* @param message
*/
public BillWebServiceFault(String message)
{
super(message);
// TODO Auto-generated constructor stub
}
/**
* @param message
* @param cause
*/
public BillWebServiceFault(String message, Throwable cause)
{
super(message, cause);
// TODO Auto-generated constructor stub
}
/**
* @param cause
*/
public BillWebServiceFault(Throwable cause)
{
super(cause);
// TODO Auto-generated constructor stub
}
Here's my service description in the .wsdd
<service name="BillWebService" provider="java:RPC" style="wrapped" use="literal">
<responseFlow>
<handler type="SOAPMessageLogging"/>
</responseFlow>
<parameter name="allowedMethods" value="*"/>
<parameter name="className" value="com.sabre.cruise.webservices.prototype.BillWebService"/>
<wsdlFile>/BillWebService.wsdl</wsdlFile>
<beanMapping languageSpecificType="java:com.sabre.cruise.webservices.prototype.ComplexDataType"/>
<beanMapping languageSpecificType="java:com.sabre.cruise.webservices.prototype.ReallyComplexDataType"/>
</service>
Finally, here's the javatowsdl Ant task:
<!-- 3) Generate the WSDL (This can be done automatically by Axis, but we've chosen to do it ahead of time) -->
<target name="generateWSDL" depends="createJar">
<axis-java2wsdl classname="com.sabre.cruise.webservices.prototype.BillWebService"
methods="HelloWorld"
output="wsdl/BillWebService.wsdl"
location="http://localhost:8080/Calculate_axis/services/BillWebService"
namespace="http://localhost:8080/Calculate_axis/services/BillWebService"
namespaceImpl="http://localhost:8080/Calculate_axis/services/BillWebService"
style="WRAPPED"
>
<classpath path="lib/Calculate.jar" />
</axis-java2wsdl>
</target>
Bill Heitzeg
1-734-995-9131
Bill Heitzeg
1-734-995-9131