cxf-issues mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From Sebastian Hoß (JIRA) <>
Subject [jira] [Created] (CXF-7210) StringIndexOutOfBoundsException during construction of failover request
Date Wed, 11 Jan 2017 12:38:58 GMT
Sebastian Hoß created CXF-7210:

             Summary: StringIndexOutOfBoundsException during construction of failover request
                 Key: CXF-7210
             Project: CXF
          Issue Type: Bug
          Components: JAX-RS
            Reporter: Sebastian Hoß
            Priority: Trivial

In {{AbstractClient}} we [have the following|]:

UriBuilder builder = new UriBuilderImpl().uri(newBaseURI);
String basePath = reqURIPath.startsWith(baseURIPath) ? baseURIPath : getBaseURI().getRawPath();

builder.path(reqURIPath.equals(basePath) ? "" : reqURIPath.substring(basePath.length()));

This covers two out of three potential cases:

1) {{baseURIPath}} and {{reqURIPath}} have the same value which will result in only the base
path being added to the builder.
2) {{baseURIPath}} and {{reqURIPath}} have a different value in which case the builder will
get the base path and and everything from the request path that is not already included in
the base path.

What's missing (and what is causing the exception below) is that the base path might be longer
than the request path in which case {{reqURIPath.substring(basePath.length())}} throws the
following stack trace:

Caused by: java.lang.StringIndexOutOfBoundsException: String index out of range: -7
  at java.lang.String.substring(
  at org.apache.cxf.jaxrs.client.AbstractClient.calculateNewRequestURI(
  at org.apache.cxf.jaxrs.client.AbstractClient.calculateNewRequestURI(
  at org.apache.cxf.jaxrs.client.AbstractClient.retryInvoke(
  at org.apache.cxf.jaxrs.client.AbstractClient$RetryableImpl.invoke(
  at org.apache.cxf.clustering.FailoverTargetSelector.performFailover(
  at org.apache.cxf.clustering.FailoverTargetSelector.complete(
  at org.talend.esb.servicelocator.cxf.internal.LocatorTargetSelector.complete(
  at org.apache.cxf.jaxrs.client.AbstractClient.preProcessResult(

This message was sent by Atlassian JIRA

View raw message