HTTPCLIENT-900: Don't enforce URI syntax for messages with an explicit target host
git-svn-id: https://svn.apache.org/repos/asf/httpcomponents/httpclient/trunk@1424591 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
38e6a997fc
commit
e99b061a95
|
@ -1,6 +1,9 @@
|
||||||
Changes in trunk
|
Changes in trunk
|
||||||
-------------------
|
-------------------
|
||||||
|
|
||||||
|
* [HTTPCLIENT-900] Don't enforce URI syntax for messages with an explicit target host.
|
||||||
|
Contributed by Oleg Kalnichevski <olegk at apache.org>
|
||||||
|
|
||||||
* [HTTPCLIENT-1250] Allow query string to be ignored when determining cacheability for HTTP 1.0
|
* [HTTPCLIENT-1250] Allow query string to be ignored when determining cacheability for HTTP 1.0
|
||||||
responses.
|
responses.
|
||||||
Contributed by Don Brown <mrdon at twdata.org>
|
Contributed by Don Brown <mrdon at twdata.org>
|
||||||
|
|
|
@ -45,7 +45,6 @@ import org.apache.http.annotation.Immutable;
|
||||||
import org.apache.http.client.CookieStore;
|
import org.apache.http.client.CookieStore;
|
||||||
import org.apache.http.client.config.CookieSpecs;
|
import org.apache.http.client.config.CookieSpecs;
|
||||||
import org.apache.http.client.config.RequestConfig;
|
import org.apache.http.client.config.RequestConfig;
|
||||||
import org.apache.http.client.methods.HttpUriRequest;
|
|
||||||
import org.apache.http.config.Lookup;
|
import org.apache.http.config.Lookup;
|
||||||
import org.apache.http.conn.routing.RouteInfo;
|
import org.apache.http.conn.routing.RouteInfo;
|
||||||
import org.apache.http.cookie.Cookie;
|
import org.apache.http.cookie.Cookie;
|
||||||
|
@ -55,6 +54,7 @@ import org.apache.http.cookie.CookieSpecProvider;
|
||||||
import org.apache.http.cookie.SetCookie2;
|
import org.apache.http.cookie.SetCookie2;
|
||||||
import org.apache.http.protocol.HttpContext;
|
import org.apache.http.protocol.HttpContext;
|
||||||
import org.apache.http.util.Args;
|
import org.apache.http.util.Args;
|
||||||
|
import org.apache.http.util.TextUtils;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Request interceptor that matches cookies available in the current
|
* Request interceptor that matches cookies available in the current
|
||||||
|
@ -121,17 +121,12 @@ public class RequestAddCookies implements HttpRequestInterceptor {
|
||||||
this.log.debug("CookieSpec selected: " + policy);
|
this.log.debug("CookieSpec selected: " + policy);
|
||||||
}
|
}
|
||||||
|
|
||||||
URI requestURI;
|
URI requestURI = null;
|
||||||
if (request instanceof HttpUriRequest) {
|
try {
|
||||||
requestURI = ((HttpUriRequest) request).getURI();
|
requestURI = new URI(request.getRequestLine().getUri());
|
||||||
} else {
|
} catch (URISyntaxException ignore) {
|
||||||
try {
|
|
||||||
requestURI = new URI(request.getRequestLine().getUri());
|
|
||||||
} catch (URISyntaxException ignore) {
|
|
||||||
requestURI = null;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
String path = requestURI != null ? requestURI.getPath() : null;
|
||||||
String hostName = targetHost.getHostName();
|
String hostName = targetHost.getHostName();
|
||||||
int port = targetHost.getPort();
|
int port = targetHost.getPort();
|
||||||
if (port < 0) {
|
if (port < 0) {
|
||||||
|
@ -141,7 +136,7 @@ public class RequestAddCookies implements HttpRequestInterceptor {
|
||||||
CookieOrigin cookieOrigin = new CookieOrigin(
|
CookieOrigin cookieOrigin = new CookieOrigin(
|
||||||
hostName,
|
hostName,
|
||||||
port >= 0 ? port : 0,
|
port >= 0 ? port : 0,
|
||||||
requestURI != null ? requestURI.getPath() : "/",
|
!TextUtils.isEmpty(path) ? path : "/",
|
||||||
route.isSecure());
|
route.isSecure());
|
||||||
|
|
||||||
// Get an instance of the selected cookie policy
|
// Get an instance of the selected cookie policy
|
||||||
|
|
|
@ -43,6 +43,7 @@ import org.apache.http.client.methods.HttpPost;
|
||||||
import org.apache.http.entity.InputStreamEntity;
|
import org.apache.http.entity.InputStreamEntity;
|
||||||
import org.apache.http.entity.StringEntity;
|
import org.apache.http.entity.StringEntity;
|
||||||
import org.apache.http.impl.client.HttpClients;
|
import org.apache.http.impl.client.HttpClients;
|
||||||
|
import org.apache.http.message.BasicHttpRequest;
|
||||||
import org.apache.http.protocol.BasicHttpContext;
|
import org.apache.http.protocol.BasicHttpContext;
|
||||||
import org.apache.http.protocol.ExecutionContext;
|
import org.apache.http.protocol.ExecutionContext;
|
||||||
import org.apache.http.protocol.HttpContext;
|
import org.apache.http.protocol.HttpContext;
|
||||||
|
@ -197,4 +198,22 @@ public class TestClientRequestExecution extends IntegrationTestBase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testNonCompliantURI() throws Exception {
|
||||||
|
this.localServer.register("*", new SimpleService());
|
||||||
|
this.httpclient = HttpClients.createDefault();
|
||||||
|
|
||||||
|
HttpContext context = new BasicHttpContext();
|
||||||
|
BasicHttpRequest request = new BasicHttpRequest("GET", "blah.:.blah.:.");
|
||||||
|
HttpResponse response = this.httpclient.execute(getServerHttp(), request, context);
|
||||||
|
EntityUtils.consume(response.getEntity());
|
||||||
|
|
||||||
|
Assert.assertEquals(HttpStatus.SC_OK, response.getStatusLine().getStatusCode());
|
||||||
|
|
||||||
|
HttpRequest reqWrapper = (HttpRequest) context.getAttribute(
|
||||||
|
ExecutionContext.HTTP_REQUEST);
|
||||||
|
|
||||||
|
Assert.assertEquals("blah.:.blah.:.", reqWrapper.getRequestLine().getUri());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue