Cleanup of redirect request generation code in Redirect exec interceptors
This commit is contained in:
parent
8b29c0680b
commit
b6b89a7296
|
@ -53,9 +53,9 @@ import org.apache.hc.core5.http.HttpResponse;
|
||||||
import org.apache.hc.core5.http.HttpStatus;
|
import org.apache.hc.core5.http.HttpStatus;
|
||||||
import org.apache.hc.core5.http.Method;
|
import org.apache.hc.core5.http.Method;
|
||||||
import org.apache.hc.core5.http.ProtocolException;
|
import org.apache.hc.core5.http.ProtocolException;
|
||||||
import org.apache.hc.core5.http.message.BasicHttpRequest;
|
|
||||||
import org.apache.hc.core5.http.nio.AsyncDataConsumer;
|
import org.apache.hc.core5.http.nio.AsyncDataConsumer;
|
||||||
import org.apache.hc.core5.http.nio.AsyncEntityProducer;
|
import org.apache.hc.core5.http.nio.AsyncEntityProducer;
|
||||||
|
import org.apache.hc.core5.http.support.BasicRequestBuilder;
|
||||||
import org.apache.hc.core5.util.LangUtils;
|
import org.apache.hc.core5.util.LangUtils;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
@ -136,34 +136,38 @@ public final class AsyncRedirectExec implements AsyncExecChainHandler {
|
||||||
}
|
}
|
||||||
state.redirectLocations.add(redirectUri);
|
state.redirectLocations.add(redirectUri);
|
||||||
|
|
||||||
final int statusCode = response.getCode();
|
|
||||||
|
|
||||||
state.currentRequest = null;
|
|
||||||
switch (statusCode) {
|
|
||||||
case HttpStatus.SC_MOVED_PERMANENTLY:
|
|
||||||
case HttpStatus.SC_MOVED_TEMPORARILY:
|
|
||||||
if (Method.POST.isSame(request.getMethod())) {
|
|
||||||
state.currentRequest = new BasicHttpRequest(Method.GET, redirectUri);
|
|
||||||
state.currentEntityProducer = null;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case HttpStatus.SC_SEE_OTHER:
|
|
||||||
if (!Method.GET.isSame(request.getMethod()) && !Method.HEAD.isSame(request.getMethod())) {
|
|
||||||
state.currentRequest = new BasicHttpRequest(Method.GET, redirectUri);
|
|
||||||
state.currentEntityProducer = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (state.currentRequest == null) {
|
|
||||||
state.currentRequest = new BasicHttpRequest(request.getMethod(), redirectUri);
|
|
||||||
}
|
|
||||||
state.currentRequest.setHeaders(scope.originalRequest.getHeaders());
|
|
||||||
final HttpHost newTarget = URIUtils.extractHost(redirectUri);
|
final HttpHost newTarget = URIUtils.extractHost(redirectUri);
|
||||||
if (newTarget == null) {
|
if (newTarget == null) {
|
||||||
throw new ProtocolException("Redirect URI does not specify a valid host name: " + redirectUri);
|
throw new ProtocolException("Redirect URI does not specify a valid host name: " + redirectUri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final int statusCode = response.getCode();
|
||||||
|
final BasicRequestBuilder redirectBuilder;
|
||||||
|
switch (statusCode) {
|
||||||
|
case HttpStatus.SC_MOVED_PERMANENTLY:
|
||||||
|
case HttpStatus.SC_MOVED_TEMPORARILY:
|
||||||
|
if (Method.POST.isSame(request.getMethod())) {
|
||||||
|
redirectBuilder = BasicRequestBuilder.get();
|
||||||
|
state.currentEntityProducer = null;
|
||||||
|
} else {
|
||||||
|
redirectBuilder = BasicRequestBuilder.copy(scope.originalRequest);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case HttpStatus.SC_SEE_OTHER:
|
||||||
|
if (!Method.GET.isSame(request.getMethod()) && !Method.HEAD.isSame(request.getMethod())) {
|
||||||
|
redirectBuilder = BasicRequestBuilder.get();
|
||||||
|
state.currentEntityProducer = null;
|
||||||
|
} else {
|
||||||
|
redirectBuilder = BasicRequestBuilder.copy(scope.originalRequest);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
redirectBuilder = BasicRequestBuilder.copy(scope.originalRequest);
|
||||||
|
}
|
||||||
|
redirectBuilder.setUri(redirectUri);
|
||||||
state.reroute = false;
|
state.reroute = false;
|
||||||
state.redirectURI = redirectUri;
|
state.redirectURI = redirectUri;
|
||||||
|
state.currentRequest = redirectBuilder.build();
|
||||||
|
|
||||||
if (!LangUtils.equals(currentRoute.getTargetHost(), newTarget)) {
|
if (!LangUtils.equals(currentRoute.getTargetHost(), newTarget)) {
|
||||||
final HttpRoute newRoute = routePlanner.determineRoute(newTarget, clientContext);
|
final HttpRoute newRoute = routePlanner.determineRoute(newTarget, clientContext);
|
||||||
|
|
|
@ -36,7 +36,6 @@ import org.apache.hc.client5.http.RedirectException;
|
||||||
import org.apache.hc.client5.http.auth.AuthExchange;
|
import org.apache.hc.client5.http.auth.AuthExchange;
|
||||||
import org.apache.hc.client5.http.classic.ExecChain;
|
import org.apache.hc.client5.http.classic.ExecChain;
|
||||||
import org.apache.hc.client5.http.classic.ExecChainHandler;
|
import org.apache.hc.client5.http.classic.ExecChainHandler;
|
||||||
import org.apache.hc.client5.http.classic.methods.HttpGet;
|
|
||||||
import org.apache.hc.client5.http.config.RequestConfig;
|
import org.apache.hc.client5.http.config.RequestConfig;
|
||||||
import org.apache.hc.client5.http.protocol.HttpClientContext;
|
import org.apache.hc.client5.http.protocol.HttpClientContext;
|
||||||
import org.apache.hc.client5.http.protocol.RedirectLocations;
|
import org.apache.hc.client5.http.protocol.RedirectLocations;
|
||||||
|
@ -55,7 +54,7 @@ import org.apache.hc.core5.http.HttpStatus;
|
||||||
import org.apache.hc.core5.http.Method;
|
import org.apache.hc.core5.http.Method;
|
||||||
import org.apache.hc.core5.http.ProtocolException;
|
import org.apache.hc.core5.http.ProtocolException;
|
||||||
import org.apache.hc.core5.http.io.entity.EntityUtils;
|
import org.apache.hc.core5.http.io.entity.EntityUtils;
|
||||||
import org.apache.hc.core5.http.message.BasicClassicHttpRequest;
|
import org.apache.hc.core5.http.io.support.ClassicRequestBuilder;
|
||||||
import org.apache.hc.core5.util.Args;
|
import org.apache.hc.core5.util.Args;
|
||||||
import org.apache.hc.core5.util.LangUtils;
|
import org.apache.hc.core5.util.LangUtils;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -132,6 +131,13 @@ public final class RedirectExec implements ExecChainHandler {
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("{} redirect requested to location '{}'", exchangeId, redirectUri);
|
LOG.debug("{} redirect requested to location '{}'", exchangeId, redirectUri);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final HttpHost newTarget = URIUtils.extractHost(redirectUri);
|
||||||
|
if (newTarget == null) {
|
||||||
|
throw new ProtocolException("Redirect URI does not specify a valid host name: " +
|
||||||
|
redirectUri);
|
||||||
|
}
|
||||||
|
|
||||||
if (!config.isCircularRedirectsAllowed()) {
|
if (!config.isCircularRedirectsAllowed()) {
|
||||||
if (redirectLocations.contains(redirectUri)) {
|
if (redirectLocations.contains(redirectUri)) {
|
||||||
throw new CircularRedirectException("Circular redirect to '" + redirectUri + "'");
|
throw new CircularRedirectException("Circular redirect to '" + redirectUri + "'");
|
||||||
|
@ -139,32 +145,28 @@ public final class RedirectExec implements ExecChainHandler {
|
||||||
}
|
}
|
||||||
redirectLocations.add(redirectUri);
|
redirectLocations.add(redirectUri);
|
||||||
|
|
||||||
final ClassicHttpRequest originalRequest = scope.originalRequest;
|
|
||||||
ClassicHttpRequest redirect = null;
|
|
||||||
final int statusCode = response.getCode();
|
final int statusCode = response.getCode();
|
||||||
|
final ClassicRequestBuilder redirectBuilder;
|
||||||
switch (statusCode) {
|
switch (statusCode) {
|
||||||
case HttpStatus.SC_MOVED_PERMANENTLY:
|
case HttpStatus.SC_MOVED_PERMANENTLY:
|
||||||
case HttpStatus.SC_MOVED_TEMPORARILY:
|
case HttpStatus.SC_MOVED_TEMPORARILY:
|
||||||
if (Method.POST.isSame(request.getMethod())) {
|
if (Method.POST.isSame(request.getMethod())) {
|
||||||
redirect = new HttpGet(redirectUri);
|
redirectBuilder = ClassicRequestBuilder.get();
|
||||||
|
} else {
|
||||||
|
redirectBuilder = ClassicRequestBuilder.copy(scope.originalRequest);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case HttpStatus.SC_SEE_OTHER:
|
case HttpStatus.SC_SEE_OTHER:
|
||||||
if (!Method.GET.isSame(request.getMethod()) && !Method.HEAD.isSame(request.getMethod())) {
|
if (!Method.GET.isSame(request.getMethod()) && !Method.HEAD.isSame(request.getMethod())) {
|
||||||
redirect = new HttpGet(redirectUri);
|
redirectBuilder = ClassicRequestBuilder.get();
|
||||||
|
} else {
|
||||||
|
redirectBuilder = ClassicRequestBuilder.copy(scope.originalRequest);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
redirectBuilder = ClassicRequestBuilder.copy(scope.originalRequest);
|
||||||
}
|
}
|
||||||
if (redirect == null) {
|
redirectBuilder.setUri(redirectUri);
|
||||||
redirect = new BasicClassicHttpRequest(originalRequest.getMethod(), redirectUri);
|
|
||||||
redirect.setEntity(originalRequest.getEntity());
|
|
||||||
}
|
|
||||||
redirect.setHeaders(originalRequest.getHeaders());
|
|
||||||
|
|
||||||
final HttpHost newTarget = URIUtils.extractHost(redirectUri);
|
|
||||||
if (newTarget == null) {
|
|
||||||
throw new ProtocolException("Redirect URI does not specify a valid host name: " +
|
|
||||||
redirectUri);
|
|
||||||
}
|
|
||||||
|
|
||||||
final HttpRoute currentRoute = currentScope.route;
|
final HttpRoute currentRoute = currentScope.route;
|
||||||
if (!LangUtils.equals(currentRoute.getTargetHost(), newTarget)) {
|
if (!LangUtils.equals(currentRoute.getTargetHost(), newTarget)) {
|
||||||
|
@ -199,7 +201,7 @@ public final class RedirectExec implements ExecChainHandler {
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("{} redirecting to '{}' via {}", exchangeId, redirectUri, currentRoute);
|
LOG.debug("{} redirecting to '{}' via {}", exchangeId, redirectUri, currentRoute);
|
||||||
}
|
}
|
||||||
currentRequest = redirect;
|
currentRequest = redirectBuilder.build();
|
||||||
RequestEntityProxy.enhance(currentRequest);
|
RequestEntityProxy.enhance(currentRequest);
|
||||||
|
|
||||||
EntityUtils.consume(response.getEntity());
|
EntityUtils.consume(response.getEntity());
|
||||||
|
|
Loading…
Reference in New Issue