Control characters like that are illegal in XML.  You can read Benson's blog 
about it:
http://dssheep.blogspot.com/2008/01/xml-10-versus-web-services.html

Technically, I would consider this a bug in the JAXB marshaller as this should 
have thrown an exception at write time, not read time.    If you turn on 
schema validation on the send side, it might throw an exception, not really 
sure.   

Dan


On Thursday 28 August 2008 6:01:00 pm Martijn Brinkers wrote:
> Hi,
>
> I use CXF as a soap server and CXF as a soap client. In one of my soap
> calls I return a String but sometimes this results in a
> WstxUnexpectedCharException.
>
> "WstxUnexpectedCharException: Illegal character ((CTRL-CHAR, code 27))"
>
> I read that a WstxUnexpectedCharException can be caused by a HTML server
> returning HTML content but that's not the case here. The string that's
> returned is returned by my CXF soap server. Shouldn't it be escaped or
> something?
>
> Thanks,
>
> Martijn Brinkers
>
> PS. I use CXF 2.1
>
>
>
> Partial stacktrace
>
> Caused by: org.apache.cxf.interceptor.Fault: Unmarshalling Error:
> Illegal character ((CTRL-CHAR, code 27))
> at [row,col {unknown-source}]: [7,1]
> at
> org.apache.cxf.jaxb.JAXBEncoderDecoder.unmarshall(JAXBEncoderDecoder.java:6
>42) at
> org.apache.cxf.jaxb.JAXBEncoderDecoder.unmarshall(JAXBEncoderDecoder.java:5
>55) at org.apache.cxf.jaxb.io.DataReaderImpl.read(DataReaderImpl.java:64) at
> org.apache.cxf.interceptor.DocLiteralInInterceptor.handleMessage(DocLiteral
>InInterceptor.java:102) at
> org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChai
>n.java:221) at
> org.apache.cxf.endpoint.ClientImpl.onMessage(ClientImpl.java:429) at
> org.apache.cxf.transport.http.HTTPConduit
> $WrappedOutputStream.handleResponse(HTTPConduit.java:1988)
> at org.apache.cxf.transport.http.HTTPConduit
> $WrappedOutputStream.close(HTTPConduit.java:1824)
> at
> org.apache.cxf.transport.AbstractConduit.close(AbstractConduit.java:66)
> at org.apache.cxf.transport.http.HTTPConduit.close(HTTPConduit.java:583)
> at org.apache.cxf.interceptor.MessageSenderInterceptor
> $MessageSenderEndingInterceptor.handleMessage(MessageSenderInterceptor.java
>:62) at
> org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChai
>n.java:221) at
> org.apache.cxf.endpoint.ClientImpl.invoke(ClientImpl.java:276)
> at org.apache.cxf.endpoint.ClientImpl.invoke(ClientImpl.java:222)
> at org.apache.cxf.frontend.ClientProxy.invokeSync(ClientProxy.java:73)
> at
> org.apache.cxf.jaxws.JaxWsClientProxy.invoke(JaxWsClientProxy.java:177)
> ... 111 more
> Caused by: javax.xml.bind.UnmarshalException
> - with linked exception:
> [com.ctc.wstx.exc.WstxUnexpectedCharException: Illegal character
> ((CTRL-CHAR, code 27))
> at [row,col {unknown-source}]: [7,1]]
> at
> com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallerImpl.handleStreamExcep
>tion(UnmarshallerImpl.java:422) at
> com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallerImpl.unmarshal0(Unmars
>hallerImpl.java:360) at
> com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallerImpl.unmarshal(Unmarsh
>allerImpl.java:337) at
> org.apache.cxf.jaxb.JAXBEncoderDecoder.unmarshall(JAXBEncoderDecoder.java:6
>28) ... 126 more
> Caused by: com.ctc.wstx.exc.WstxUnexpectedCharException: Illegal
> character ((CTRL-CHAR, code 27))
> at [row,col {unknown-source}]: [7,1]
> at
> com.ctc.wstx.sr.StreamScanner.throwInvalidSpace(StreamScanner.java:650)
> at
> com.ctc.wstx.sr.BasicStreamReader.readTextSecondary(BasicStreamReader.java:
>4666) at
> com.ctc.wstx.sr.BasicStreamReader.readCoalescedText(BasicStreamReader.java:
>4124) at
> com.ctc.wstx.sr.BasicStreamReader.finishToken(BasicStreamReader.java:3699)
> at
> com.ctc.wstx.sr.BasicStreamReader.safeFinishToken(BasicStreamReader.java:36
>47) at
> com.ctc.wstx.sr.BasicStreamReader.getTextCharacters(BasicStreamReader.java:
>830) at
> org.apache.cxf.staxutils.DepthXMLStreamReader.getTextCharacters(DepthXMLStr
>eamReader.java:159) at
> com.sun.xml.bind.v2.runtime.unmarshaller.StAXStreamConnector.handleCharacte
>rs(StAXStreamConnector.java:356) at
> com.sun.xml.bind.v2.runtime.unmarshaller.StAXStreamConnector.bridge(StAXStr
>eamConnector.java:220) at
> com.sun.xml.bind.v2.runtime.unmarshaller.UnmarshallerImpl.unmarshal0(Unmars
>hallerImpl.java:358) ... 128 more



-- 
Daniel Kulp
[EMAIL PROTECTED]
http://www.dankulp.com/blog

Reply via email to