Hi

Perhaps it is not registered ? do you have a bean with id
"invalidEquipmentIdExceptionMapper" ? Can you try 
<bean class="package.InvalidEquipmentIdExceptionMapper"/>

If it still does not work then can you post a sample resource and exception
classes ?
thanks, Sergey


bloody_peasant wrote:
> 
> Hi,
> 
> I've got a pretty simple example using CXF 2.2.5 and Spring 2.5.4.  I am
> setup in my spring for both SOAP and REST services, but am only testing
> the REST service right now.  I have a simple service that throws an
> exception and have registered a simple ExceptionMapper, but the mapper is
> never being called.  The exception is being converted into a Fault and
> handled instead by XMLFaultOutInterceptor.  With my debugger I can see
> that my mapper is never being called.  What am I doing wrong?
> 
> Thanks
> 
> John McGinn
> 
> My mapper class looks like this:
> @Provider
> public class InvalidEquipmentIdExceptionMapper implements
> ExceptionMapper<InvalidEquipmentIdException> {
> 
>         public Response toResponse(InvalidEquipmentIdException e) {
> 
>                 EquipmentValidationResponse response = new
> EquipmentValidationResponse();
> 
>                 response.setMessageHeader(new
> MessageHeaderResponseType());
>                 response.getMessageHeader().setCorrelationId("TEST");
>                 response.getMessageHeader().setSender("RAIL");
>                 response.getMessageHeader().setReceiver("TEST");
>                
> response.getMessageHeader().setTimestamp(Calendar.getInstance());
>                 response.getMessageHeader().setResultDetails(new
> ResultDetailsType());
> 
>                 response.getMessageHeader().setResult("FAILED");
>                
> response.getMessageHeader().setResultDescription("Equipment ID is Not in a
> Valid Format");
>                 ErrorDetailType error = new ErrorDetailType();
>                 error.setResultCode("INVALID_EQUIP_ID");
>                 error.setDescription(e.getMessage());
>                
> response.getMessageHeader().getResultDetails().getResultDetails().add(error);
> 
>                 return
> Response.status(Status.BAD_REQUEST).entity(response).type("application/xml").build();
>                 //throw new
> WebApplicationException(Response.status(Status.BAD_REQUEST).entity(response).type("application/xml").build());
>         }
> }
> 
> My spring JAXRS config looks like this:
>         <jaxrs:server id="restService" address="/services/">
>                 <jaxrs:providers>
>                         <ref bean="invalidEquipmentIdExceptionMapper"/>
>                 </jaxrs:providers>
>                 <jaxrs:serviceBeans>
>                         <ref bean="equipmentServiceImpl" />
>                 </jaxrs:serviceBeans>
>         </jaxrs:server>
> 
> When I call the service with a certain value it throws
> InvalidEquipmentIdException (a checked exception).
> 
> In my log I see the following:
> 2010-01-07 11:31:24,377 http-8080-2 DEBUG
> [apache.cxf.phase.PhaseInterceptorChain] Invoking handleMessage on
> interceptor
> org.apache.cxf.binding.xml.interceptor.xmlfaultoutintercep...@b2c64
> 2010-01-07 11:31:24,377 http-8080-2 DEBUG
> [apache.cxf.phase.PhaseInterceptorChain] Application has thrown exception,
> unwinding now
> org.apache.cxf.interceptor.Fault: Equipment Number must be numeric
>         at
> org.apache.cxf.service.invoker.AbstractInvoker.createFault(AbstractInvoker.java:155)
>         at
> org.apache.cxf.service.invoker.AbstractInvoker.invoke(AbstractInvoker.java:121)
>         at org.apache.cxf.jaxrs.JAXRSInvoker.invoke(JAXRSInvoker.java:130)
>         at org.apache.cxf.jaxrs.JAXRSInvoker.invoke(JAXRSInvoker.java:82)
>         at
> org.apache.cxf.interceptor.ServiceInvokerInterceptor$1.run(ServiceInvokerInterceptor.java:58)
>         at
> java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:417)
>         at
> java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:269)
>         at java.util.concurrent.FutureTask.run(FutureTask.java:123)
>         at
> org.apache.cxf.workqueue.SynchronousExecutor.execute(SynchronousExecutor.java:37)
>         at
> org.apache.cxf.interceptor.ServiceInvokerInterceptor.handleMessage(ServiceInvokerInterceptor.java:106)
>         at
> org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:236)
>         at
> org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:109)
>         at
> org.apache.cxf.transport.servlet.ServletDestination.invoke(ServletDestination.java:98)
>         at
> org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:394)
>         at
> org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:133)
>         at
> org.apache.cxf.transport.servlet.AbstractCXFServlet.invoke(AbstractCXFServlet.java:142)
>         at
> org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:179)
>         at
> org.apache.cxf.transport.servlet.AbstractHTTPServlet.doGet(AbstractHTTPServlet.java:108)
>         at javax.servlet.http.HttpServlet.service(HttpServlet.java:690)
>         at
> org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:159)
>         at
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
>         at
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
>         at
> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
>         at
> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
>         at
> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
>         at
> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
>         at
> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
>         at
> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:263)
>         at
> org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
>         at
> org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:584)
>         at
> org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
>         at java.lang.Thread.run(Thread.java:595)
> Caused by:
> com.railinc.test.work4.equipment.services.InvalidEquipmentIdException:
> Equipment Number must be numeric
>         at
> com.railinc.test.work4.equipment.services.impl.ExampleEquipmentLookupServiceImpl.lookupEquipment(ExampleEquipmentLookupServiceImpl.java:44)
>         at
> com.railinc.test.work4.eq.services.impl.ExampleEquipmentServiceImpl.getEquipment(ExampleEquipmentServiceImpl.java:59)
>         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>         at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
>         at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at
> org.apache.cxf.service.invoker.AbstractInvoker.performInvocation(AbstractInvoker.java:173)
>         at
> org.apache.cxf.service.invoker.AbstractInvoker.invoke(AbstractInvoker.java:89)
>         ... 30 more
> 
> CXFServlet eventually converts this into a RuntimeException.
> 
> This email and any files transmitted with it are confidential and intended
> solely for the use of the individual or entity to whom they are addressed.
> If you have received this email in error please notify the system manager.
> This message contains confidential information and is intended only for
> the individual named. If you are not the named addressee you should not
> disseminate, distribute or copy this e-mail.
> 
> 

-- 
View this message in context: 
http://old.nabble.com/ExceptionMapper-not-being-called-tp27062948p27063169.html
Sent from the cxf-user mailing list archive at Nabble.com.

Reply via email to