ContentType of JMS response ignored
-----------------------------------
Key: AXIS2-4089
URL: https://issues.apache.org/jira/browse/AXIS2-4089
Project: Axis 2.0 (Axis2)
Issue Type: Bug
Components: kernel, transports
Affects Versions: 1.4
Environment: OS: Windows XP Pro 2002 Service Pack 2
Reporter: Cathal Callaghan
The ContentType of a JMS response message is ignored by the client.
This causes major hassle when the response message contains a MIME attachment
i.e MTOM
When the a JMS client receieves the response from the server it does not look
at its contentType. This means that the SOAPMessageFormatter assumes that its a
standard SOAP response. If a MIME attachment is present in the response and
consequently its contentType should be "multipart/related", the parser throws
the below exception.
I have attached a fix for this issue. The class affected is Please note that
this fix is cumulative with the fix submitted as part of
(https://issues.apache.org/jira/browse/AXIS2-4025). Unfortunately network
restrictions forbid me from issueing a patch.
For convienience i have detailed the lines changed below:
Thanks,
Cathal
<<begin lines changed>>
<imports>
import org.apache.axis2.builder.BuilderUtil;
import org.apache.axis2.wsdl.WSDLConstants;
<imports>
Message reply = consumer.receive(timeout);
if (reply != null) {
msgContext.setProperty(MessageContext.TRANSPORT_IN,
JMSUtils.getInputStream(reply));
/*
* The contentType of the server response is never taken into account
* This fix retrieves the contentTpye and sets it on the appropriate
messageContext
* This is especially required for receiving MIME attachments correctly
*/
String contentType = JMSUtils.getProperty(reply,
JMSConstants.CONTENT_TYPE);
String charSetEnc = BuilderUtil.getCharSetEncoding(contentType);
MessageContext inMessageContext =
msgContext.getOperationContext().getMessageContext(
WSDLConstants.MESSAGE_LABEL_IN_VALUE);
if (inMessageContext != null) {
inMessageContext.setProperty(Constants.Configuration.CONTENT_TYPE, contentType);
inMessageContext.setProperty(Constants.Configuration.CHARACTER_SET_ENCODING,
charSetEnc);
}
}
<<end lines changed>>
<<begin exception thrown>>
org.apache.axis2.AxisFault: com.ctc.wstx.exc.WstxUnexpectedCharException:
Unexpected character '-' (code 45) in prolog; expected '<'
at [row,col {unknown-source}]: [1,1]
at org.apache.axis2.AxisFault.makeFault(AxisFault.java:430)
at
org.apache.axis2.transport.TransportUtils.createSOAPMessage(TransportUtils.java:90)
at
org.apache.axis2.description.OutInAxisOperationClient.handleResponse(OutInAxisOperation.java:353)
at
org.apache.axis2.description.OutInAxisOperationClient.send(OutInAxisOperation.java:416)
at
org.apache.axis2.description.OutInAxisOperationClient.executeImpl(OutInAxisOperation.java:228)
at
org.apache.axis2.client.OperationClient.execute(OperationClient.java:163)
at
com.fineos.frontoffice.documentproduction.operationtypes.DocProdServicesStub.uploadFile(DocProdServicesStub.java:863)
at
com.fineos.productservices.test.frontoffice.docprodservices.DocProdServicesTest.testUploadFile(DocProdServicesTest.java:280)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at
com.fineos.ta.test.driver.TaTestResult$1.protect(TaTestResult.java:230)
at
com.fineos.ta.test.driver.TaTestResult.runProtected(TaTestResult.java:242)
at com.fineos.ta.test.driver.TaTestResult.run(TaTestResult.java:233)
at com.fineos.ta.test.driver.TaTestCase.run(TaTestCase.java:127)
at com.fineos.ta.test.driver.console.Driver.doRun(Driver.java:137)
at com.fineos.ta.test.driver.console.Driver.start(Driver.java:105)
at
com.fineos.ta.test.driver.AbstractDriver.initTA(AbstractDriver.java:376)
at com.fineos.ta.test.driver.console.Driver.<init>(Driver.java:69)
at com.fineos.ta.test.driver.console.Driver.main(Driver.java:73)
Caused by: org.apache.axiom.om.OMException:
com.ctc.wstx.exc.WstxUnexpectedCharException: Unexpected character '-' (code
45) in prolog; expected '<'
at [row,col {unknown-source}]: [1,1]
at
org.apache.axiom.om.impl.builder.StAXOMBuilder.next(StAXOMBuilder.java:249)
at
org.apache.axiom.soap.impl.builder.StAXSOAPModelBuilder.getSOAPEnvelope(StAXSOAPModelBuilder.java:156)
at
org.apache.axiom.soap.impl.builder.StAXSOAPModelBuilder.<init>(StAXSOAPModelBuilder.java:105)
at
org.apache.axis2.builder.BuilderUtil.getSOAPBuilder(BuilderUtil.java:677)
at
org.apache.axis2.transport.TransportUtils.createDocumentElement(TransportUtils.java:182)
at
org.apache.axis2.transport.TransportUtils.createSOAPMessage(TransportUtils.java:112)
at
org.apache.axis2.transport.TransportUtils.createSOAPMessage(TransportUtils.java:88)
... 25 more
Caused by: com.ctc.wstx.exc.WstxUnexpectedCharException: Unexpected character
'-' (code 45) in prolog; expected '<'
at [row,col {unknown-source}]: [1,1]
at
com.ctc.wstx.sr.StreamScanner.throwUnexpectedChar(StreamScanner.java:623)
at
com.ctc.wstx.sr.BasicStreamReader.nextFromProlog(BasicStreamReader.java:2047)
at com.ctc.wstx.sr.BasicStreamReader.next(BasicStreamReader.java:1069)
at
org.apache.axiom.om.impl.builder.StAXOMBuilder.parserNext(StAXOMBuilder.java:506)
at
org.apache.axiom.om.impl.builder.StAXOMBuilder.next(StAXOMBuilder.java:161)
... 31 more
<<end exception thrown>>
--
This message is automatically generated by JIRA.
-
You can reply to this email to add a comment to the issue online.
---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]