How to include HolderInInterceptor at cxfendpoint while sending request ?

Solution Verified - Updated -

Issue

  • User want to overwrite the HolderInInterceptor at the cxfendpoint. This is because the default one is throwing an IndexOutOfBoundsException.
  • See https://developer.jboss.org/thread/252207.
  • Or generally how can one overwrite a camel cxf default interceptor, to use a custom one? How will one set this in their blueprint.xml configurations?
  • Error logs
2015-08-21 09:30:04,587 | WARN  | qtp47244505-65   | TransactionErrorHandler          | ?                                   ? | 142 - org.apache.camel.camel-core - 2.12.0.redhat-610379
| Transaction rollback (0x5714366a) redelivered(unknown) for (MessageId: ID-SP-182100-012-53058-1440081049193-5-4 on ExchangeId: ID-SP-182100-012-53058-1440081049193-5-5) caught: java.l
ang.IndexOutOfBoundsException: Index: 1, Size: 1
2015-08-21 09:30:04,590 | WARN  | qtp47244505-65   | PhaseInterceptorChain            | ?                                   ? | 164 - org.apache.cxf.cxf-api - 2.7.0.redhat-610379 | Appl
ication xxx.yyy.zz has thrown exception, unwinding now
org.apache.cxf.interceptor.Fault: java.lang.IndexOutOfBoundsException: Index: 1, Size: 1
        at org.apache.camel.component.cxf.CxfConsumer$1.checkFailure(CxfConsumer.java:228)[205:org.apache.camel.camel-cxf:2.12.0.redhat-610379]
        at org.apache.camel.component.cxf.CxfConsumer$1.setResponseBack(CxfConsumer.java:206)[205:org.apache.camel.camel-cxf:2.12.0.redhat-610379]
        at org.apache.camel.component.cxf.CxfConsumer$1.asyncInvoke(CxfConsumer.java:107)[205:org.apache.camel.camel-cxf:2.12.0.redhat-610379]
        at org.apache.camel.component.cxf.CxfConsumer$1.invoke(CxfConsumer.java:72)[205:org.apache.camel.camel-cxf:2.12.0.redhat-610379]
        at org.apache.cxf.interceptor.ServiceInvokerInterceptor$1.run(ServiceInvokerInterceptor.java:58)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.interceptor.ServiceInvokerInterceptor.handleMessage(ServiceInvokerInterceptor.java:94)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:272)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.phase.PhaseInterceptorChain.resume(PhaseInterceptorChain.java:242)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:78)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.transport.http.AbstractHTTPDestination.invoke(AbstractHTTPDestination.java:239)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:248)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:222)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:153)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.CXFNonSpringServlet.invoke(CXFNonSpringServlet.java:167)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:286)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.AbstractHTTPServlet.doPost(AbstractHTTPServlet.java:206)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:595)[91:org.apache.geronimo.specs.geronimo-servlet_3.0_spec:1.0]
        at org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:262)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:684)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:501)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.ops4j.pax.web.service.jetty.internal.HttpServiceServletHandler.doHandle(HttpServiceServletHandler.java:69)[100:org.ops4j.pax.web.pax-web-jetty:3.0.6]
        at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:533)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1086)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.ops4j.pax.web.service.jetty.internal.HttpServiceContext.doHandle(HttpServiceContext.java:219)[100:org.ops4j.pax.web.pax-web-jetty:3.0.6]
        at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:428)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1020)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.ops4j.pax.web.service.jetty.internal.JettyServerHandlerCollection.handle(JettyServerHandlerCollection.java:77)[100:org.ops4j.pax.web.pax-web-jetty:3.0.6]
        at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.Server.handleAsync(Server.java:410)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:519)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.AbstractHttpConnection.content(AbstractHttpConnection.java:982)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.AbstractHttpConnection$RequestHandler.content(AbstractHttpConnection.java:1043)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:865)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.http.HttpParser.parseAvailable(HttpParser.java:240)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.AsyncHttpConnection.handle(AsyncHttpConnection.java:82)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.io.nio.SelectChannelEndPoint.handle(SelectChannelEndPoint.java:667)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.io.nio.SelectChannelEndPoint$1.run(SelectChannelEndPoint.java:52)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:608)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.util.thread.QueuedThreadPool$3.run(QueuedThreadPool.java:543)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at java.lang.Thread.run(Thread.java:745)[:1.7.0_75]
Caused by: org.apache.camel.RuntimeCamelException: java.lang.IndexOutOfBoundsException: Index: 1, Size: 1
        at org.apache.camel.util.ObjectHelper.wrapRuntimeCamelException(ObjectHelper.java:1363)[142:org.apache.camel.camel-core:2.12.0.redhat-610379]
        at org.apache.camel.spring.spi.TransactionErrorHandler$1.doInTransactionWithoutResult(TransactionErrorHandler.java:188)[149:org.apache.camel.camel-spring:2.12.0.redhat-610379]
        at org.springframework.transaction.support.TransactionCallbackWithoutResult.doInTransaction(TransactionCallbackWithoutResult.java:33)[148:org.apache.servicemix.bundles.spring-tx
:3.2.8.RELEASE_1]
        at org.springframework.transaction.support.TransactionTemplate.execute(TransactionTemplate.java:131)[148:org.apache.servicemix.bundles.spring-tx:3.2.8.RELEASE_1]
        at org.apache.camel.spring.spi.TransactionErrorHandler.doInTransactionTemplate(TransactionErrorHandler.java:174)[149:org.apache.camel.camel-spring:2.12.0.redhat-610379]
        at org.apache.camel.spring.spi.TransactionErrorHandler.processInTransaction(TransactionErrorHandler.java:134)[149:org.apache.camel.camel-spring:2.12.0.redhat-610379]
        at org.apache.camel.spring.spi.TransactionErrorHandler.process(TransactionErrorHandler.java:103)[149:org.apache.camel.camel-spring:2.12.0.redhat-610379]
        at org.apache.camel.spring.spi.TransactionErrorHandler.process(TransactionErrorHandler.java:112)[149:org.apache.camel.camel-spring:2.12.0.redhat-610379]
        at org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:191)[142:org.apache.camel.camel-core:2.12.0.redhat-610379]
        at org.apache.camel.processor.CamelInternalProcessor.process(CamelInternalProcessor.java:191)[142:org.apache.camel.camel-core:2.12.0.redhat-610379]
        at org.apache.camel.component.cxf.CxfConsumer$1.asyncInvoke(CxfConsumer.java:92)[205:org.apache.camel.camel-cxf:2.12.0.redhat-610379]
        at org.apache.camel.component.cxf.CxfConsumer$1.invoke(CxfConsumer.java:72)[205:org.apache.camel.camel-cxf:2.12.0.redhat-610379]
        at org.apache.cxf.interceptor.ServiceInvokerInterceptor$1.run(ServiceInvokerInterceptor.java:58)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:471)[:1.7.0_75]
        at java.util.concurrent.FutureTask.run(FutureTask.java:262)[:1.7.0_75]
        at org.apache.cxf.workqueue.SynchronousExecutor.execute(SynchronousExecutor.java:37)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.interceptor.ServiceInvokerInterceptor.handleMessage(ServiceInvokerInterceptor.java:107)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:272)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.transport.ChainInitiationObserver.onMessage(ChainInitiationObserver.java:121)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.transport.http.AbstractHTTPDestination.invoke(AbstractHTTPDestination.java:239)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.ServletController.invokeDestination(ServletController.java:248)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:222)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.ServletController.invoke(ServletController.java:153)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.CXFNonSpringServlet.invoke(CXFNonSpringServlet.java:167)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.AbstractHTTPServlet.handleRequest(AbstractHTTPServlet.java:286)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.servlet.AbstractHTTPServlet.doPost(AbstractHTTPServlet.java:206)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:595)[91:org.apache.geronimo.specs.geronimo-servlet_3.0_spec:1.0]
        at org.apache.cxf.transport.servlet.AbstractHTTPServlet.service(AbstractHTTPServlet.java:262)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.eclipse.jetty.servlet.ServletHolder.handle(ServletHolder.java:684)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.servlet.ServletHandler.doHandle(ServletHandler.java:501)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.ops4j.pax.web.service.jetty.internal.HttpServiceServletHandler.doHandle(HttpServiceServletHandler.java:69)[100:org.ops4j.pax.web.pax-web-jetty:3.0.6]
        at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:137)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.security.SecurityHandler.handle(SecurityHandler.java:533)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.session.SessionHandler.doHandle(SessionHandler.java:231)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.handler.ContextHandler.doHandle(ContextHandler.java:1086)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.ops4j.pax.web.service.jetty.internal.HttpServiceContext.doHandle(HttpServiceContext.java:219)[100:org.ops4j.pax.web.pax-web-jetty:3.0.6]
        at org.eclipse.jetty.servlet.ServletHandler.doScope(ServletHandler.java:428)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.session.SessionHandler.doScope(SessionHandler.java:193)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.handler.ContextHandler.doScope(ContextHandler.java:1020)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.handler.ScopedHandler.handle(ScopedHandler.java:135)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.ops4j.pax.web.service.jetty.internal.JettyServerHandlerCollection.handle(JettyServerHandlerCollection.java:77)[100:org.ops4j.pax.web.pax-web-jetty:3.0.6]
        at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:116)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.Server.handle(Server.java:370)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        at org.eclipse.jetty.server.AbstractHttpConnection.handleRequest(AbstractHttpConnection.java:494)[92:org.eclipse.jetty.aggregate.jetty-all-server:8.1.14.v20131031]
        ... 10 more
Caused by: java.lang.IndexOutOfBoundsException: Index: 1, Size: 1
        at java.util.ArrayList.rangeCheck(ArrayList.java:635)[:1.7.0_75]
        at java.util.ArrayList.get(ArrayList.java:411)[:1.7.0_75]
        at org.apache.cxf.jaxws.interceptors.HolderInInterceptor.handleMessage(HolderInInterceptor.java:67)[172:org.apache.cxf.cxf-rt-frontend-jaxws:2.7.0.redhat-610379]
        at org.apache.cxf.phase.PhaseInterceptorChain.doIntercept(PhaseInterceptorChain.java:272)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.endpoint.ClientImpl.onMessage(ClientImpl.java:817)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream.handleResponseInternal(HTTPConduit.java:1614)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.transport.http.HTTPConduit$WrappedOutputStream$1.run(HTTPConduit.java:1129)[170:org.apache.cxf.cxf-rt-transports-http:2.7.0.redhat-610379]
        at org.apache.cxf.workqueue.AutomaticWorkQueueImpl$3.run(AutomaticWorkQueueImpl.java:428)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)[:1.7.0_75]
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)[:1.7.0_75]
        at org.apache.cxf.workqueue.AutomaticWorkQueueImpl$AWQThreadFactory$1.run(AutomaticWorkQueueImpl.java:353)[164:org.apache.cxf.cxf-api:2.7.0.redhat-610379]
        ... 1 more
2015-08-21 09:30:04,597 | ERROR | ault-workqueue-2 | DefaultErrorHandler              | ?                                   ? | 142 - org.apache.camel.camel-core - 2.12.0.redhat-610379
| Failed delivery for (MessageId: ID-SP-182100-012-53058-1440081049193-5-6 on ExchangeId: ID-SP-182100-012-53058-1440081049193-5-5). Exhausted after delivery attempt: 1 caught: java.lan
g.IndexOutOfBoundsException: Index: 1, Size: 1

Environment

  • Red Hat JBoss Fuse
    • 6.1.0

Subscriber exclusive content

A Red Hat subscription provides unlimited access to our knowledgebase of over 48,000 articles and solutions.

Current Customers and Partners

Log in for full access

Log In
Close

Welcome! Check out the Getting Started with Red Hat page for quick tours and guides for common tasks.