Ah... strikeiron. :-(
I signed up this morning and have the NFL thing up and running in the
debugger now. I'm digging into it to figure out what's happening.
Dan
On May 20, 2008, at 10:54 AM, JSP wrote:
I just ran through the debugger and the problem is the same as when
I was
using 2.0.5. Everything I mentioned previously is still the same -
that is,
the MessagePartInfo.getTypeClass() method returns null which causes
the
JAXBEncoderDecoder to attempt to unmarshal a Node without a class.
Then it
goes into the bowels of JAXB which throws this exception:
unexpected element (uri:"http://ws.strikeiron.com",
local:"SubscriptionInfo"). Expected elements are
<{http://www.strikeiron.com}GetAllStatuses>,<{http://www.strikeiron.com
}GetAllStatusesResponse>,<{http://
www.strikeiron.com}GetAllTeamNicknames>,<{http://
www.strikeiron.com}GetAllTeamNicknamesResponse>,<{http://www.strikeiron.com
}GetRemainingHits>,<{http://
www.strikeiron.com}GetRemainingHitsResponse>,<{http://www.strikeiron.com
}GetServiceInfo>,<{http://
www.strikeiron.com}GetServiceInfoResponse>,<{http://
www.strikeiron.com}GetTeamInfoByCity>,<{http://
www.strikeiron.com}GetTeamInfoByCityResponse>,<{http://www.strikeiron.com
}GetTeamInfoByNickname>,<{http://
www.strikeiron.com}GetTeamInfoByNicknameResponse>
Again, it does not have a stack trace.
Is the MessagePartInfo.getTypeClass() supposed to be set to the
appropriate
class for a soap output header? Maybe there is some annotation that
would
cause this to happen? Or should JAXB be able to unmarshall the output
header without the class? It has the correct element.
Let me know if I can provide any more information.
dkulp wrote:
Well, unfortunately, that's a pretty useless stack trace. That NPE
is occuring while trying to create the Fault to represent the real
error. Thus, the real error from JAXB is lost. :-(
I've committed a fix to the JAXBEncoderDecoder that will hopefully
fix
that so we can see what the real error is. I'll get a new snapshot
deployed later today, but if you can checkout the code and build/test
with that, maybe we can at least see the real error.
Dan
On May 19, 2008, at 11:17 PM, JSP wrote:
We are now using 2.1 and I am still getting the same error, although
the line
numbers have changed. I haven't done any debugging of it yet, just
wanted
to see if you had any ideas first?
Here is the updated stack trace:
May 19, 2008 11:14:07 PM org.apache.cxf.phase.PhaseInterceptorChain
doIntercept
INFO: Interceptor has thrown exception, unwinding now
java.lang.NullPointerException
at
org
.apache
.cxf.jaxb.JAXBEncoderDecoder.unmarshall(JAXBEncoderDecoder.java:642)
at
org
.apache
.cxf.jaxb.JAXBEncoderDecoder.unmarshall(JAXBEncoderDecoder.java:555)
at org.apache.cxf.jaxb.io.DataReaderImpl.read(DataReaderImpl.java:
64)
at
org
.apache
.cxf
.binding
.soap
.interceptor
.SoapHeaderInterceptor.handleMessage(SoapHeaderInterceptor.java:101)
at
org
.apache
.cxf
.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.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
.io
.CacheAndWriteOutputStream.postClose(CacheAndWriteOutputStream.java:
47)
at
org.apache.cxf.io.CachedOutputStream.close(CachedOutputStream.java:
159)
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(PhaseInterceptorChain.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)
Let me know if I can provide any additional information.
JSP wrote:
I'll try 2.0.6 and let you know.
dkulp wrote:
Can you try with 2.0.6 or 2.1? I added checks for
MessagePartInfo.getTypeClass() == null in several areas for
2.1/2.0.6. That may have taken care of this.
Dan
On May 14, 2008, at 3:32 PM, JSP wrote:
I am trying to consume one of the strikeiron web services which
take
an input
soap header and return an output soap header. When I execute a
request that
has an input soap header and an output soap header I get a null
pointer
exception. The request is sent successfully and the response is
recieved
but it cannot be unmarshalled. The null pointer exception is
misleading
because it occurs when handling another exception. This is the
null
pointer
exception:
Caused by: java.lang.NullPointerException
at
org
.apache
.cxf.jaxb.JAXBEncoderDecoder.unmarshall(JAXBEncoderDecoder.java:
592)
at
org
.apache
.cxf.jaxb.JAXBEncoderDecoder.unmarshall(JAXBEncoderDecoder.java:
498)
at
org.apache.cxf.jaxb.io.DataReaderImpl.read(DataReaderImpl.java:
40)
at
org
.apache
.cxf
.binding
.soap
.interceptor
.SoapHeaderInterceptor.handleMessage(SoapHeaderInterceptor.java:
101)
This is the actual exception (unfortunately no stack trace):
javax.xml.bind.UnmarshalException: unexpected element
(uri:"http://ws.strikeiron.com", local:"SubscriptionInfo").
Expected
elements are
<{http://www.strikeiron.com}GetAllStatuses>,<{http://www.strikeiron.com
}GetAllStatusesResponse>,<{http://
www.strikeiron.com}GetAllTeamNicknames>,<{http://
www.strikeiron.com}GetAllTeamNicknamesResponse>,<{http://www.strikeiron.com
}GetRemainingHits>,<{http://
www.strikeiron.com}GetRemainingHitsResponse>,<{http://www.strikeiron.com
}GetServiceInfo>,<{http://
www.strikeiron.com}GetServiceInfoResponse>,<{http://
www.strikeiron.com}GetTeamInfoByCity>,<{http://
www.strikeiron.com}GetTeamInfoByCityResponse>,<{http://www.strikeiron.com
}GetTeamInfoByNickname>,<{http://
www.strikeiron.com}GetTeamInfoByNicknameResponse>
I have traced through the code and it looks like cxf is trying to
unmarshal
a Node without a class.
Snippet of code from JAXBEncoderDecoder (unmarshalWithClass is
false):
if (source instanceof Node) {
obj = unmarshalWithClass ? u.unmarshal((Node)source,
clazz)
: u.unmarshal((Node)source);
} else if (source instanceof XMLStreamReader) {
And that is because the MessagePartInfo.getTypeClass() method
returns null.
I cannot find a place where the type class is set for the
MessagePartInfo
for the output soap header.
I have included a snippet of my interface if that helps - I'm
thinking I
must have something annotated incorrectly.
@ResponseWrapper(className =
"data
.footballws
.sdpnflteamssoap.com.strikeiron.www.GetAllTeamNicknamesResponse",
targetNamespace = "http://www.strikeiron.com", localName =
"GetAllTeamNicknamesResponse")
@RequestWrapper(className =
"data
.footballws
.sdpnflteamssoap.com.strikeiron.www.GetAllTeamNicknames",
targetNamespace = "http://www.strikeiron.com", localName =
"GetAllTeamNicknames")
@WebMethod(action = "http://www.strikeiron.com/
GetAllTeamNicknames",
operationName = "GetAllTeamNicknames")
public void _GetAllTeamNicknames(@WebParam(partName =
"LicenseInfoPart",
header = true, mode = WebParam.Mode.IN, targetNamespace =
"http://www.strikeiron.com", name = "LicenseInfo")
LicenseInfo LicenseInfo, @WebParam(partName =
"GetAllTeamNicknamesResultPart", mode = WebParam.Mode.OUT,
targetNamespace =
"http://www.strikeiron.com", name = "GetAllTeamNicknamesResult")
Holder<NFLTeamOutput> GetAllTeamNicknamesResult,
@WebParam(partName =
"SubscriptionInfoPart", header = true, mode = WebParam.Mode.OUT,
targetNamespace = "http://www.strikeiron.com", name =
"SubscriptionInfo")
Holder<SubscriptionInfo> SubscriptionInfo);
Does anybody have an idea what I might be doing wrong?
BTW - I am using 2.0.5.
--
View this message in context:
http://www.nabble.com/NullPointerException-decoding-response-with-SOAP-header-tp17239110p17239110.html
Sent from the cxf-user mailing list archive at Nabble.com.
---
Daniel Kulp
[EMAIL PROTECTED]
http://www.dankulp.com/blog
--
View this message in context:
http://www.nabble.com/NullPointerException-decoding-response-with-SOAP-header-tp17239110p17332466.html
Sent from the cxf-user mailing list archive at Nabble.com.
---
Daniel Kulp
[EMAIL PROTECTED]
http://www.dankulp.com/blog
--
View this message in context:
http://www.nabble.com/NullPointerException-decoding-response-with-SOAP-header-tp17239110p17342443.html
Sent from the cxf-user mailing list archive at Nabble.com.
---
Daniel Kulp
[EMAIL PROTECTED]
http://www.dankulp.com/blog