* Redesigned the way the local execution context is handled: If a custom context is given, it gets wrapped with the DefaultedHttpContext that defaults to the parent execution context containing default values of all mandatory execution attributes. Therefore the local context can now contain only those attributes the user wishes to override. There is no longer a need to populate the local context with all mandatory attributes.
* Added a new context parameter for preferred auth schemes git-svn-id: https://svn.apache.org/repos/asf/httpcomponents/httpclient/trunk@654886 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
8c8174514e
commit
e4f8eee752
|
@ -59,10 +59,8 @@ public class ClientCustomContext {
|
||||||
// Create a local instance of cookie store
|
// Create a local instance of cookie store
|
||||||
CookieStore cookieStore = new BasicCookieStore();
|
CookieStore cookieStore = new BasicCookieStore();
|
||||||
|
|
||||||
// Obtain default HTTP context
|
|
||||||
HttpContext defaultContext = httpclient.getDefaultContext();
|
|
||||||
// Create local HTTP context
|
// Create local HTTP context
|
||||||
HttpContext localContext = new BasicHttpContext(defaultContext);
|
HttpContext localContext = new BasicHttpContext();
|
||||||
// Bind custom cookie store to the local context
|
// Bind custom cookie store to the local context
|
||||||
localContext.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
localContext.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
||||||
|
|
||||||
|
|
|
@ -56,9 +56,8 @@ public class ClientInteractiveAuthentication {
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
DefaultHttpClient httpclient = new DefaultHttpClient();
|
DefaultHttpClient httpclient = new DefaultHttpClient();
|
||||||
|
|
||||||
// Create custom execution context
|
// Create local execution context
|
||||||
// We'll need it in order to get hold of the authentication state object
|
HttpContext localContext = new BasicHttpContext();
|
||||||
HttpContext localContext = new BasicHttpContext(httpclient.getDefaultContext());
|
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("http://localhost/test");
|
HttpGet httpget = new HttpGet("http://localhost/test");
|
||||||
|
|
||||||
|
|
|
@ -110,7 +110,7 @@ public class ClientMultiThreadedExecution {
|
||||||
|
|
||||||
public GetThread(HttpClient httpClient, HttpGet httpget, int id) {
|
public GetThread(HttpClient httpClient, HttpGet httpget, int id) {
|
||||||
this.httpClient = httpClient;
|
this.httpClient = httpClient;
|
||||||
this.context = new BasicHttpContext(httpClient.getDefaultContext());
|
this.context = new BasicHttpContext();
|
||||||
this.httpget = httpget;
|
this.httpget = httpget;
|
||||||
this.id = id;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,17 +61,6 @@ import org.apache.http.conn.ClientConnectionManager;
|
||||||
public interface HttpClient {
|
public interface HttpClient {
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Obtains the default context used by this client populated with
|
|
||||||
* default attributes. This context will be used by default when
|
|
||||||
* executing requests with this client.
|
|
||||||
*
|
|
||||||
* @return the default context
|
|
||||||
*/
|
|
||||||
HttpContext getDefaultContext()
|
|
||||||
;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Obtains the parameters for this client.
|
* Obtains the parameters for this client.
|
||||||
* These parameters will become defaults for all requests being
|
* These parameters will become defaults for all requests being
|
||||||
|
|
|
@ -46,4 +46,6 @@ public interface ClientContext {
|
||||||
public static final String CREDS_PROVIDER = "http.auth.credentials-provider";
|
public static final String CREDS_PROVIDER = "http.auth.credentials-provider";
|
||||||
public static final String TARGET_AUTH_STATE = "http.auth.target-scope";
|
public static final String TARGET_AUTH_STATE = "http.auth.target-scope";
|
||||||
public static final String PROXY_AUTH_STATE = "http.auth.proxy-scope";
|
public static final String PROXY_AUTH_STATE = "http.auth.proxy-scope";
|
||||||
|
public static final String AUTH_SCHEME_PREF = "http.auth.scheme-pref";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* $HeadURL:$
|
* $HeadURL$
|
||||||
* $Revision:$
|
* $Revision$
|
||||||
* $Date:$
|
* $Date$
|
||||||
*
|
*
|
||||||
* ====================================================================
|
* ====================================================================
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
@ -31,20 +31,42 @@
|
||||||
|
|
||||||
package org.apache.http.client.protocol;
|
package org.apache.http.client.protocol;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.apache.http.auth.AuthSchemeRegistry;
|
||||||
import org.apache.http.client.CookieStore;
|
import org.apache.http.client.CookieStore;
|
||||||
|
import org.apache.http.client.CredentialsProvider;
|
||||||
|
import org.apache.http.cookie.CookieSpecRegistry;
|
||||||
import org.apache.http.protocol.HttpContext;
|
import org.apache.http.protocol.HttpContext;
|
||||||
|
|
||||||
public class ClientContextConfigurer {
|
public class ClientContextConfigurer implements ClientContext {
|
||||||
|
|
||||||
private final HttpContext context;
|
private final HttpContext context;
|
||||||
|
|
||||||
public ClientContextConfigurer (final HttpContext context) {
|
public ClientContextConfigurer (final HttpContext context) {
|
||||||
if (context == null)
|
if (context == null)
|
||||||
throw new IllegalArgumentException("'context' must be set");
|
throw new IllegalArgumentException("HTTP context may not be null");
|
||||||
this.context = context;
|
this.context = context;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setCookieStore (final CookieStore cookieStore) {
|
public void setCookieSpecRegistry(final CookieSpecRegistry registry) {
|
||||||
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
this.context.setAttribute(COOKIESPEC_REGISTRY, registry);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAuthSchemeRegistry(final AuthSchemeRegistry registry) {
|
||||||
|
this.context.setAttribute(AUTHSCHEME_REGISTRY, registry);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCookieStore(final CookieStore store) {
|
||||||
|
this.context.setAttribute(COOKIE_STORE, store);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setCredentialsProvider(final CredentialsProvider provider) {
|
||||||
|
this.context.setAttribute(CREDS_PROVIDER, provider);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAuthSchemePref(final List<String> list) {
|
||||||
|
this.context.setAttribute(AUTH_SCHEME_PREF, list);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,6 +60,7 @@ public abstract class AbstractAuthenticationHandler implements AuthenticationHan
|
||||||
private static final Log LOG = LogFactory.getLog(AbstractAuthenticationHandler.class);
|
private static final Log LOG = LogFactory.getLog(AbstractAuthenticationHandler.class);
|
||||||
|
|
||||||
private static final List<String> DEFAULT_SCHEME_PRIORITY = Arrays.asList(new String[] {
|
private static final List<String> DEFAULT_SCHEME_PRIORITY = Arrays.asList(new String[] {
|
||||||
|
"ntlm",
|
||||||
"digest",
|
"digest",
|
||||||
"basic"
|
"basic"
|
||||||
});
|
});
|
||||||
|
@ -116,14 +117,20 @@ public abstract class AbstractAuthenticationHandler implements AuthenticationHan
|
||||||
throw new IllegalStateException("AuthScheme registry not set in HTTP context");
|
throw new IllegalStateException("AuthScheme registry not set in HTTP context");
|
||||||
}
|
}
|
||||||
|
|
||||||
List<String> authPrefs = getAuthPreferences();
|
List<?> authPrefs = (List<?>) context.getAttribute(
|
||||||
|
ClientContext.AUTH_SCHEME_PREF);
|
||||||
|
if (authPrefs == null) {
|
||||||
|
authPrefs = getAuthPreferences();
|
||||||
|
}
|
||||||
|
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("Supported authentication schemes in the order of preference: "
|
LOG.debug("Authentication schemes in the order of preference: "
|
||||||
+ authPrefs);
|
+ authPrefs);
|
||||||
}
|
}
|
||||||
|
|
||||||
AuthScheme authScheme = null;
|
AuthScheme authScheme = null;
|
||||||
for (String id : authPrefs) {
|
for (int i = 0; i < authPrefs.size(); i++) {
|
||||||
|
String id = (String) authPrefs.get(i);
|
||||||
Header challenge = challenges.get(id.toLowerCase(Locale.ENGLISH));
|
Header challenge = challenges.get(id.toLowerCase(Locale.ENGLISH));
|
||||||
|
|
||||||
if (challenge != null) {
|
if (challenge != null) {
|
||||||
|
@ -132,10 +139,13 @@ public abstract class AbstractAuthenticationHandler implements AuthenticationHan
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
authScheme = registry.getAuthScheme(id, response.getParams());
|
authScheme = registry.getAuthScheme(id, response.getParams());
|
||||||
} catch (IllegalStateException e) {
|
|
||||||
throw new AuthenticationException(e.getMessage());
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
} catch (IllegalStateException e) {
|
||||||
|
if (LOG.isWarnEnabled()) {
|
||||||
|
LOG.warn("Authentication scheme " + id + " not supported");
|
||||||
|
// Try again
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (LOG.isDebugEnabled()) {
|
if (LOG.isDebugEnabled()) {
|
||||||
LOG.debug("Challenge for " + id + " authentication scheme not available");
|
LOG.debug("Challenge for " + id + " authentication scheme not available");
|
||||||
|
|
|
@ -50,11 +50,13 @@ import org.apache.http.client.HttpClient;
|
||||||
import org.apache.http.client.HttpRequestRetryHandler;
|
import org.apache.http.client.HttpRequestRetryHandler;
|
||||||
import org.apache.http.client.RedirectHandler;
|
import org.apache.http.client.RedirectHandler;
|
||||||
import org.apache.http.client.methods.HttpUriRequest;
|
import org.apache.http.client.methods.HttpUriRequest;
|
||||||
|
import org.apache.http.client.protocol.ClientContext;
|
||||||
import org.apache.http.conn.ClientConnectionManager;
|
import org.apache.http.conn.ClientConnectionManager;
|
||||||
import org.apache.http.conn.routing.HttpRoutePlanner;
|
import org.apache.http.conn.routing.HttpRoutePlanner;
|
||||||
import org.apache.http.cookie.CookieSpecRegistry;
|
import org.apache.http.cookie.CookieSpecRegistry;
|
||||||
import org.apache.http.params.HttpParams;
|
import org.apache.http.params.HttpParams;
|
||||||
import org.apache.http.protocol.BasicHttpProcessor;
|
import org.apache.http.protocol.BasicHttpProcessor;
|
||||||
|
import org.apache.http.protocol.DefaultedHttpContext;
|
||||||
import org.apache.http.protocol.HttpContext;
|
import org.apache.http.protocol.HttpContext;
|
||||||
import org.apache.http.protocol.BasicHttpContext;
|
import org.apache.http.protocol.BasicHttpContext;
|
||||||
import org.apache.http.protocol.HttpProcessor;
|
import org.apache.http.protocol.HttpProcessor;
|
||||||
|
@ -72,9 +74,6 @@ import org.apache.http.protocol.HttpProcessor;
|
||||||
*/
|
*/
|
||||||
public abstract class AbstractHttpClient implements HttpClient {
|
public abstract class AbstractHttpClient implements HttpClient {
|
||||||
|
|
||||||
/** The default context. */
|
|
||||||
private HttpContext defaultContext;
|
|
||||||
|
|
||||||
/** The parameters. */
|
/** The parameters. */
|
||||||
private HttpParams defaultParams;
|
private HttpParams defaultParams;
|
||||||
|
|
||||||
|
@ -167,9 +166,6 @@ public abstract class AbstractHttpClient implements HttpClient {
|
||||||
protected abstract CredentialsProvider createCredentialsProvider();
|
protected abstract CredentialsProvider createCredentialsProvider();
|
||||||
|
|
||||||
|
|
||||||
protected abstract void populateContext(HttpContext context);
|
|
||||||
|
|
||||||
|
|
||||||
protected abstract HttpRoutePlanner createHttpRoutePlanner();
|
protected abstract HttpRoutePlanner createHttpRoutePlanner();
|
||||||
|
|
||||||
|
|
||||||
|
@ -346,15 +342,6 @@ public abstract class AbstractHttpClient implements HttpClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public synchronized final HttpContext getDefaultContext() {
|
|
||||||
if (defaultContext == null) {
|
|
||||||
defaultContext = createHttpContext();
|
|
||||||
}
|
|
||||||
populateContext(defaultContext);
|
|
||||||
return defaultContext;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public synchronized void addResponseInterceptor(final HttpResponseInterceptor itcp) {
|
public synchronized void addResponseInterceptor(final HttpResponseInterceptor itcp) {
|
||||||
getHttpProcessor().addInterceptor(itcp);
|
getHttpProcessor().addInterceptor(itcp);
|
||||||
}
|
}
|
||||||
|
@ -477,13 +464,31 @@ public abstract class AbstractHttpClient implements HttpClient {
|
||||||
// a null target may be acceptable, this depends on the route planner
|
// a null target may be acceptable, this depends on the route planner
|
||||||
// a null context is acceptable, default context created below
|
// a null context is acceptable, default context created below
|
||||||
|
|
||||||
|
HttpContext execContext = null;
|
||||||
ClientRequestDirector director = null;
|
ClientRequestDirector director = null;
|
||||||
|
|
||||||
// Initialize the request execution context making copies of
|
// Initialize the request execution context making copies of
|
||||||
// all shared objects that are potentially threading unsafe.
|
// all shared objects that are potentially threading unsafe.
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
|
|
||||||
|
HttpContext defaultContext = new BasicHttpContext(null);
|
||||||
|
defaultContext.setAttribute(
|
||||||
|
ClientContext.AUTHSCHEME_REGISTRY,
|
||||||
|
getAuthSchemes());
|
||||||
|
defaultContext.setAttribute(
|
||||||
|
ClientContext.COOKIESPEC_REGISTRY,
|
||||||
|
getCookieSpecs());
|
||||||
|
defaultContext.setAttribute(
|
||||||
|
ClientContext.COOKIE_STORE,
|
||||||
|
getCookieStore());
|
||||||
|
defaultContext.setAttribute(
|
||||||
|
ClientContext.CREDS_PROVIDER,
|
||||||
|
getCredentialsProvider());
|
||||||
|
|
||||||
if (context == null) {
|
if (context == null) {
|
||||||
context = new BasicHttpContext(getDefaultContext());
|
execContext = defaultContext;
|
||||||
|
} else {
|
||||||
|
execContext = new DefaultedHttpContext(context, defaultContext);
|
||||||
}
|
}
|
||||||
// Create a director for this request
|
// Create a director for this request
|
||||||
director = createClientRequestDirector(
|
director = createClientRequestDirector(
|
||||||
|
@ -498,7 +503,7 @@ public abstract class AbstractHttpClient implements HttpClient {
|
||||||
determineParams(request));
|
determineParams(request));
|
||||||
}
|
}
|
||||||
|
|
||||||
HttpResponse response = director.execute(target, request, context);
|
HttpResponse response = director.execute(target, request, execContext);
|
||||||
// If the response depends on the connection, the director
|
// If the response depends on the connection, the director
|
||||||
// will have set up an auto-release input stream.
|
// will have set up an auto-release input stream.
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,6 @@ import org.apache.http.client.RedirectHandler;
|
||||||
import org.apache.http.client.params.AuthPolicy;
|
import org.apache.http.client.params.AuthPolicy;
|
||||||
import org.apache.http.client.params.ClientPNames;
|
import org.apache.http.client.params.ClientPNames;
|
||||||
import org.apache.http.client.params.CookiePolicy;
|
import org.apache.http.client.params.CookiePolicy;
|
||||||
import org.apache.http.client.protocol.ClientContext;
|
|
||||||
import org.apache.http.client.protocol.RequestAddCookies;
|
import org.apache.http.client.protocol.RequestAddCookies;
|
||||||
import org.apache.http.client.protocol.RequestDefaultHeaders;
|
import org.apache.http.client.protocol.RequestDefaultHeaders;
|
||||||
import org.apache.http.client.protocol.RequestProxyAuthentication;
|
import org.apache.http.client.protocol.RequestProxyAuthentication;
|
||||||
|
@ -290,23 +289,6 @@ public class DefaultHttpClient extends AbstractHttpClient {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void populateContext(final HttpContext context) {
|
|
||||||
context.setAttribute(
|
|
||||||
ClientContext.AUTHSCHEME_REGISTRY,
|
|
||||||
getAuthSchemes());
|
|
||||||
context.setAttribute(
|
|
||||||
ClientContext.COOKIESPEC_REGISTRY,
|
|
||||||
getCookieSpecs());
|
|
||||||
context.setAttribute(
|
|
||||||
ClientContext.COOKIE_STORE,
|
|
||||||
getCookieStore());
|
|
||||||
context.setAttribute(
|
|
||||||
ClientContext.CREDS_PROVIDER,
|
|
||||||
getCredentialsProvider());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// non-javadoc, see base class AbstractHttpClient
|
// non-javadoc, see base class AbstractHttpClient
|
||||||
@Override
|
@Override
|
||||||
protected HttpRoutePlanner createHttpRoutePlanner() {
|
protected HttpRoutePlanner createHttpRoutePlanner() {
|
||||||
|
|
|
@ -53,6 +53,7 @@ import org.apache.http.impl.client.BasicCookieStore;
|
||||||
import org.apache.http.impl.client.DefaultHttpClient;
|
import org.apache.http.impl.client.DefaultHttpClient;
|
||||||
import org.apache.http.localserver.ServerTestBase;
|
import org.apache.http.localserver.ServerTestBase;
|
||||||
import org.apache.http.message.BasicHeader;
|
import org.apache.http.message.BasicHeader;
|
||||||
|
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;
|
||||||
import org.apache.http.protocol.HttpRequestHandler;
|
import org.apache.http.protocol.HttpRequestHandler;
|
||||||
|
@ -105,7 +106,7 @@ public class TestCookie2Support extends ServerTestBase {
|
||||||
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
||||||
|
|
||||||
CookieStore cookieStore = new BasicCookieStore();
|
CookieStore cookieStore = new BasicCookieStore();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/test/");
|
HttpGet httpget = new HttpGet("/test/");
|
||||||
|
@ -156,7 +157,7 @@ public class TestCookie2Support extends ServerTestBase {
|
||||||
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
||||||
|
|
||||||
CookieStore cookieStore = new BasicCookieStore();
|
CookieStore cookieStore = new BasicCookieStore();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/test/");
|
HttpGet httpget = new HttpGet("/test/");
|
||||||
|
@ -205,7 +206,7 @@ public class TestCookie2Support extends ServerTestBase {
|
||||||
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
||||||
|
|
||||||
CookieStore cookieStore = new BasicCookieStore();
|
CookieStore cookieStore = new BasicCookieStore();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/test/");
|
HttpGet httpget = new HttpGet("/test/");
|
||||||
|
@ -256,7 +257,7 @@ public class TestCookie2Support extends ServerTestBase {
|
||||||
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
client.getParams().setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.RFC_2965);
|
||||||
|
|
||||||
CookieStore cookieStore = new BasicCookieStore();
|
CookieStore cookieStore = new BasicCookieStore();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
context.setAttribute(ClientContext.COOKIE_STORE, cookieStore);
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/test/");
|
HttpGet httpget = new HttpGet("/test/");
|
||||||
|
|
|
@ -55,6 +55,7 @@ import org.apache.http.impl.client.DefaultHttpClient;
|
||||||
import org.apache.http.impl.cookie.BasicClientCookie;
|
import org.apache.http.impl.cookie.BasicClientCookie;
|
||||||
import org.apache.http.localserver.ServerTestBase;
|
import org.apache.http.localserver.ServerTestBase;
|
||||||
import org.apache.http.message.BasicHeader;
|
import org.apache.http.message.BasicHeader;
|
||||||
|
import org.apache.http.protocol.BasicHttpContext;
|
||||||
import org.apache.http.protocol.ExecutionContext;
|
import org.apache.http.protocol.ExecutionContext;
|
||||||
import org.apache.http.protocol.HTTP;
|
import org.apache.http.protocol.HTTP;
|
||||||
import org.apache.http.protocol.HttpContext;
|
import org.apache.http.protocol.HttpContext;
|
||||||
|
@ -237,7 +238,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port, HttpStatus.SC_MULTIPLE_CHOICES));
|
new BasicRedirectService(host, port, HttpStatus.SC_MULTIPLE_CHOICES));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
@ -261,7 +262,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port, HttpStatus.SC_MOVED_PERMANENTLY));
|
new BasicRedirectService(host, port, HttpStatus.SC_MOVED_PERMANENTLY));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
@ -289,7 +290,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port, HttpStatus.SC_MOVED_TEMPORARILY));
|
new BasicRedirectService(host, port, HttpStatus.SC_MOVED_TEMPORARILY));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
@ -317,7 +318,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port, HttpStatus.SC_SEE_OTHER));
|
new BasicRedirectService(host, port, HttpStatus.SC_SEE_OTHER));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
@ -345,7 +346,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port, HttpStatus.SC_NOT_MODIFIED));
|
new BasicRedirectService(host, port, HttpStatus.SC_NOT_MODIFIED));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
@ -369,7 +370,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port, HttpStatus.SC_USE_PROXY));
|
new BasicRedirectService(host, port, HttpStatus.SC_USE_PROXY));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
@ -393,7 +394,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port, HttpStatus.SC_TEMPORARY_REDIRECT));
|
new BasicRedirectService(host, port, HttpStatus.SC_TEMPORARY_REDIRECT));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
@ -453,7 +454,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
this.localServer.register("*", new BasicRedirectService(host, port));
|
this.localServer.register("*", new BasicRedirectService(host, port));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
HttpPost httppost = new HttpPost("/oldlocation/");
|
HttpPost httppost = new HttpPost("/oldlocation/");
|
||||||
httppost.setEntity(new StringEntity("stuff"));
|
httppost.setEntity(new StringEntity("stuff"));
|
||||||
|
@ -478,7 +479,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
this.localServer.register("*", new RelativeRedirectService());
|
this.localServer.register("*", new RelativeRedirectService());
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
client.getParams().setBooleanParameter(
|
client.getParams().setBooleanParameter(
|
||||||
ClientPNames.REJECT_RELATIVE_REDIRECT, false);
|
ClientPNames.REJECT_RELATIVE_REDIRECT, false);
|
||||||
|
@ -507,7 +508,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
this.localServer.register("*", new RelativeRedirectService2());
|
this.localServer.register("*", new RelativeRedirectService2());
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
client.getParams().setBooleanParameter(
|
client.getParams().setBooleanParameter(
|
||||||
ClientPNames.REJECT_RELATIVE_REDIRECT, false);
|
ClientPNames.REJECT_RELATIVE_REDIRECT, false);
|
||||||
|
@ -598,7 +599,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
|
|
||||||
cookieStore.addCookie(cookie);
|
cookieStore.addCookie(cookie);
|
||||||
|
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
HttpGet httpget = new HttpGet("/oldlocation/");
|
HttpGet httpget = new HttpGet("/oldlocation/");
|
||||||
|
|
||||||
|
|
||||||
|
@ -626,7 +627,7 @@ public class TestRedirects extends ServerTestBase {
|
||||||
new BasicRedirectService(host, port));
|
new BasicRedirectService(host, port));
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
List<Header> defaultHeaders = new ArrayList<Header>(1);
|
List<Header> defaultHeaders = new ArrayList<Header>(1);
|
||||||
defaultHeaders.add(new BasicHeader(HTTP.USER_AGENT, "my-test-client"));
|
defaultHeaders.add(new BasicHeader(HTTP.USER_AGENT, "my-test-client"));
|
||||||
|
|
|
@ -66,6 +66,7 @@ import org.apache.http.message.BasicHeader;
|
||||||
import org.apache.http.mockup.SocketFactoryMockup;
|
import org.apache.http.mockup.SocketFactoryMockup;
|
||||||
import org.apache.http.params.BasicHttpParams;
|
import org.apache.http.params.BasicHttpParams;
|
||||||
import org.apache.http.params.HttpParams;
|
import org.apache.http.params.HttpParams;
|
||||||
|
import org.apache.http.protocol.BasicHttpContext;
|
||||||
import org.apache.http.protocol.HttpContext;
|
import org.apache.http.protocol.HttpContext;
|
||||||
import org.apache.http.protocol.HttpRequestHandler;
|
import org.apache.http.protocol.HttpRequestHandler;
|
||||||
|
|
||||||
|
@ -99,7 +100,7 @@ public class TestDefaultClientRequestDirector extends ServerTestBase {
|
||||||
final AtomicReference<Throwable> throwableRef = new AtomicReference<Throwable>();
|
final AtomicReference<Throwable> throwableRef = new AtomicReference<Throwable>();
|
||||||
final CountDownLatch getLatch = new CountDownLatch(1);
|
final CountDownLatch getLatch = new CountDownLatch(1);
|
||||||
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
||||||
final HttpContext context = client.getDefaultContext();
|
final HttpContext context = new BasicHttpContext();
|
||||||
final HttpGet httpget = new HttpGet("http://www.example.com/a");
|
final HttpGet httpget = new HttpGet("http://www.example.com/a");
|
||||||
|
|
||||||
new Thread(new Runnable() {
|
new Thread(new Runnable() {
|
||||||
|
@ -140,7 +141,7 @@ public class TestDefaultClientRequestDirector extends ServerTestBase {
|
||||||
final AtomicReference<Throwable> throwableRef = new AtomicReference<Throwable>();
|
final AtomicReference<Throwable> throwableRef = new AtomicReference<Throwable>();
|
||||||
final CountDownLatch getLatch = new CountDownLatch(1);
|
final CountDownLatch getLatch = new CountDownLatch(1);
|
||||||
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
||||||
final HttpContext context = client.getDefaultContext();
|
final HttpContext context = new BasicHttpContext();
|
||||||
final HttpGet httpget = new CustomGet("a", releaseLatch);
|
final HttpGet httpget = new CustomGet("a", releaseLatch);
|
||||||
|
|
||||||
new Thread(new Runnable() {
|
new Thread(new Runnable() {
|
||||||
|
@ -181,7 +182,7 @@ public class TestDefaultClientRequestDirector extends ServerTestBase {
|
||||||
final CountDownLatch getLatch = new CountDownLatch(1);
|
final CountDownLatch getLatch = new CountDownLatch(1);
|
||||||
final CountDownLatch startLatch = new CountDownLatch(1);
|
final CountDownLatch startLatch = new CountDownLatch(1);
|
||||||
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
||||||
final HttpContext context = client.getDefaultContext();
|
final HttpContext context = new BasicHttpContext();
|
||||||
final HttpGet httpget = new HttpGet("a");
|
final HttpGet httpget = new HttpGet("a");
|
||||||
|
|
||||||
new Thread(new Runnable() {
|
new Thread(new Runnable() {
|
||||||
|
@ -228,7 +229,7 @@ public class TestDefaultClientRequestDirector extends ServerTestBase {
|
||||||
final AtomicReference<Throwable> throwableRef = new AtomicReference<Throwable>();
|
final AtomicReference<Throwable> throwableRef = new AtomicReference<Throwable>();
|
||||||
final CountDownLatch getLatch = new CountDownLatch(1);
|
final CountDownLatch getLatch = new CountDownLatch(1);
|
||||||
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
||||||
final HttpContext context = client.getDefaultContext();
|
final HttpContext context = new BasicHttpContext();
|
||||||
final HttpGet httpget = new HttpGet("a");
|
final HttpGet httpget = new HttpGet("a");
|
||||||
|
|
||||||
new Thread(new Runnable() {
|
new Thread(new Runnable() {
|
||||||
|
@ -263,7 +264,7 @@ public class TestDefaultClientRequestDirector extends ServerTestBase {
|
||||||
public void testSocketConnectFailureReleasesConnection() throws Exception {
|
public void testSocketConnectFailureReleasesConnection() throws Exception {
|
||||||
final ConnMan2 conMan = new ConnMan2();
|
final ConnMan2 conMan = new ConnMan2();
|
||||||
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
final DefaultHttpClient client = new DefaultHttpClient(conMan, new BasicHttpParams());
|
||||||
final HttpContext context = client.getDefaultContext();
|
final HttpContext context = new BasicHttpContext();
|
||||||
final HttpGet httpget = new HttpGet("http://www.example.com/a");
|
final HttpGet httpget = new HttpGet("http://www.example.com/a");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -42,6 +42,7 @@ import org.apache.http.HttpStatus;
|
||||||
import org.apache.http.client.methods.HttpGet;
|
import org.apache.http.client.methods.HttpGet;
|
||||||
import org.apache.http.entity.StringEntity;
|
import org.apache.http.entity.StringEntity;
|
||||||
import org.apache.http.localserver.ServerTestBase;
|
import org.apache.http.localserver.ServerTestBase;
|
||||||
|
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;
|
||||||
import org.apache.http.protocol.HttpRequestHandler;
|
import org.apache.http.protocol.HttpRequestHandler;
|
||||||
|
@ -91,7 +92,7 @@ public class TestRequestWrapper extends ServerTestBase {
|
||||||
this.localServer.register("*", new SimpleService());
|
this.localServer.register("*", new SimpleService());
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
String s = "http://localhost:" + port + "/path";
|
String s = "http://localhost:" + port + "/path";
|
||||||
HttpGet httpget = new HttpGet(s);
|
HttpGet httpget = new HttpGet(s);
|
||||||
|
@ -116,7 +117,7 @@ public class TestRequestWrapper extends ServerTestBase {
|
||||||
this.localServer.register("*", new SimpleService());
|
this.localServer.register("*", new SimpleService());
|
||||||
|
|
||||||
DefaultHttpClient client = new DefaultHttpClient();
|
DefaultHttpClient client = new DefaultHttpClient();
|
||||||
HttpContext context = client.getDefaultContext();
|
HttpContext context = new BasicHttpContext();
|
||||||
|
|
||||||
String s = "http://localhost:" + port;
|
String s = "http://localhost:" + port;
|
||||||
HttpGet httpget = new HttpGet(s);
|
HttpGet httpget = new HttpGet(s);
|
||||||
|
|
Loading…
Reference in New Issue