Hi All,
I'm using the cxf endpoint and having a route exposing a web service. My unit
test is sending a soap request that looks like the following
<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope"
xmlns:tim="http://services.ambulance.qld.gov.au/data/messaging/entity/services/corporate/hri/mta/eta/timesheet">
<soap:Header/>
<soap:Body>
<tim:TimesheetRequest>
<timesheetId>123</timesheetId>
</tim:TimesheetRequest>
</soap:Body>
</soap:Envelope>
Here is my endpoint definition:
CxfEndpoint endpoint = new CxfEndpoint();
endpoint.setCamelContext(getContext());
endpoint.setWsdlURL("src/main/wsdl/TimeAndAttendanceEntityService.wsdl");
endpoint.setAddress(System.getProperty("app.entity.timesheet.endpoint.address"));
endpoint.setDataFormat(DataFormat.PAYLOAD);
I then have a processor which starts with
public void process(final Exchange exchange) throws Exception {
CxfPayload requestPayload = exchange.getIn().getBody(CxfPayload.class);
I cannot seem to get around the following exception:
Caused by: java.lang.IllegalArgumentException: The PayLoad elements cannot fit
with the message parts of the BindingOperation. Please check the
BindingOperation and PayLoadMessage.
If I change the DataFormat to RAW everything works fine. Why is this happening?
From the javadocs it appears that the PAYLOAD format simply strips off all the
soap elements.
Cheers,
Matt.
This email, including any attachments sent with it, is confidential and for the
sole use of the intended recipient(s). This confidentiality is not waived or
lost, if you receive it and you are not the intended recipient(s), or if it is
transmitted/received in error.
Any unauthorised use, alteration, disclosure, distribution or review of this
email is strictly prohibited. The information contained in this email,
including any attachment sent with it, may be subject to a statutory duty of
confidentiality if it relates to health service matters.
If you are not the intended recipient(s), or if you have received this email in
error, you are asked to immediately notify the sender. You should also delete
this email, and any copies, from your computer system network and destroy any
hard copies produced.
If not an intended recipient of this email, you must not copy, distribute or
take any action(s) that relies on it; any form of disclosure, modification,
distribution and/or publication of this email is also prohibited.
Although the Queensland Ambulance Service takes all reasonable steps to ensure
this email does not contain malicious software, the Queensland Ambulance
Service does not accept responsibility for the consequences if any person's
computer inadvertently suffers any disruption to services, loss of information,
harm or is infected with a virus, other malicious computer programme or code
that may occur as a consequence of receiving this email.
Unless stated otherwise, this email represents only the views of the sender and
not the views of the Queensland Government.
********************************************************************************
The content presented in this publication is distributed by the Queensland
Government as an information source only. The State of Queensland makes no
statements, representations or warranties about the accuracy, completeness or
reliability of any information contained in this publication. The State of
Queensland disclaims all responsibility and all liability (including without
limitation for liability in negligence) for all expenses, losses, damages and
costs you might incur as a result of the information being inaccurate or
incomplete in any way, and for any reason reliance was placed on such
information.