Kirill Linnik [
http://community.jboss.org/people/kirillica] created the discussion
"Custom exceptions with @WebFault"
To view the discussion, visit:
http://community.jboss.org/message/645091#645091
--------------------------------------------------------------
Hi there,
I've tried several different combinations with no success, while case seems to be
easy.
The thing is: I need custom exception with some additional properties.
If I do smth like this (
http://io.typepad.com/eben_hewitt_on_java/tech_notes/
http://io.typepad.com/eben_hewitt_on_java/tech_notes/), I recieve:
18:12:44,553 WARN [org.apache.cxf.jaxws.interceptors.WebFaultOutInterceptor] Exception
occurred while writing fault.: org.apache.cxf.interceptor.Fault: Marshalling Error: class
my.cutsom.exception.Fault nor any of its super class is known to this context.
at org.apache.cxf.jaxb.JAXBEncoderDecoder.marshall(JAXBEncoderDecoder.java:254)
[:2.3.1-patch-01]
at org.apache.cxf.jaxb.io.DataWriterImpl.write(DataWriterImpl.java:169)
[:2.3.1-patch-01]
at
org.apache.cxf.jaxws.interceptors.WebFaultOutInterceptor.handleMessage(WebFaultOutInterceptor.java:115)
[:2.3.1-patch-01]
at
org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:255)
[:2.3.1-patch-01]
at
org.apache.cxf.interceptor.AbstractFaultChainInitiatorObserver.onMessage(AbstractFaultChainInitiatorObserver.java:99)
[:2.3.1-patch-01]
at
org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:311)
[:2.3.1-patch-01]
at
org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:113)
[:2.3.1-patch-01]
at
org.apache.cxf.transport.servlet.ServletDestination.invoke(ServletDestination.java:97)
[:2.3.1-patch-01]
at
org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:461)
[:2.3.1-patch-01]
at org.jboss.wsf.stack.cxf.ServletControllerExt.invoke(ServletControllerExt.java:172)
[:3.4.1.GA]
at
org.jboss.wsf.stack.cxf.RequestHandlerImpl.handleHttpRequest(RequestHandlerImpl.java:57)
[:3.4.1.GA]
at
org.jboss.wsf.stack.cxf.transport.ServletHelper.callRequestHandler(ServletHelper.java:156)
[:3.4.1.GA]
at
org.jboss.wsf.stack.cxf.CXFNonSpringServletExt.invoke(CXFNonSpringServletExt.java:90)
[:3.4.1.GA]
at
org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:179)
[:2.3.1-patch-01]
at
org.apache.cxf.transport.servlet.AbstractHTTPServlet.doPost(AbstractHTTPServlet.java:103)
[:2.3.1-patch-01]
at javax.servlet.http.HttpServlet.service(HttpServlet.java:754) [:1.0.0.Final]
at
org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:159)
[:2.3.1-patch-01]
at
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:324)
[:6.1.0.Final]
at
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:242)
[:6.1.0.Final]
at
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:275)
[:6.1.0.Final]
at
org.apache.catalina.core.StandardContextValve.__invoke(StandardContextValve.java:161)
[:6.1.0.Final]
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java)
[:6.1.0.Final]
at
org.jboss.web.tomcat.security.SecurityAssociationValve.invoke(SecurityAssociationValve.java:181)
[:6.1.0.Final]
at
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:593)
[:6.1.0.Final]
at
org.jboss.modcluster.catalina.CatalinaContext$RequestListenerValve.event(CatalinaContext.java:285)
[:1.1.0.Final]
at
org.jboss.modcluster.catalina.CatalinaContext$RequestListenerValve.invoke(CatalinaContext.java:261)
[:1.1.0.Final]
at org.jboss.web.tomcat.security.JaccContextValve.invoke(JaccContextValve.java:88)
[:6.1.0.Final]
at
org.jboss.web.tomcat.security.SecurityContextEstablishmentValve.invoke(SecurityContextEstablishmentValve.java:100)
[:6.1.0.Final]
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:159)
[:6.1.0.Final]
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
[:6.1.0.Final]
at
org.jboss.web.tomcat.service.jca.CachedConnectionValve.invoke(CachedConnectionValve.java:158)
[:6.1.0.Final]
at org.apache.catalina.authenticator.SingleSignOn.invoke(SingleSignOn.java:397)
[:6.1.0.Final]
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
[:6.1.0.Final]
at
org.jboss.web.tomcat.service.request.ActiveRequestResponseCacheValve.invoke(ActiveRequestResponseCacheValve.java:53)
[:6.1.0.Final]
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:362)
[:6.1.0.Final]
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:877)
[:6.1.0.Final]
at
org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:654)
[:6.1.0.Final]
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:951)
[:6.1.0.Final]
at java.lang.Thread.run(Unknown Source) [:1.6.0_29]
Code snippets:
@WebFault(name = "WebServiceException", targetNamespace =
"http://www.ww")
public class WebServiceException extends Exception {
private static final long serialVersionUID = 6441007395053274685L;
private WebServiceExceptionFaultDto faultInfo;
public WebServiceException(String message, WebServiceExceptionFaultDto faultIFault){
super(message);
this.faultInfo = faultIFault;
}
public WebServiceException(String message, WebServiceExceptionFaultDto faultIFault,
Throwable cause){
super(message, cause);
this.faultInfo = faultIFault;
}
public WebServiceExceptionFaultDto getFaultInfo() {
return faultInfo;
}
}
@XmlRootElement(name = "WebServiceException", namespace =
"http://www.ww")
@XmlType(propOrder = { "message" })
public class WebServiceExceptionFaultDto {
private String message;
public WebServiceExceptionFaultDto(String message) {
this.message = message;
}
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
}
If I do:
throw new WebServiceException("111", new
WebServiceExceptionFaultDto("222"));
Then in SOAP response I get:
<soap:Envelope
xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<soap:Fault>
<faultcode>soap:Server</faultcode>
<faultstring>111</faultstring>
<detail/>
</soap:Fault>
</soap:Body>
</soap:Envelope>
And log error like described above. Any Ideas?
Platform: JBoss6.1, Java6
Thanks in advance,
Kirill
--------------------------------------------------------------
Reply to this message by going to Community
[
http://community.jboss.org/message/645091#645091]
Start a new discussion in JBoss Web Services at Community
[
http://community.jboss.org/choose-container!input.jspa?contentType=1&...]