removed cookie handling in httpc:

- no need to do cookie handling in proxy, this was switched off so far
- no need for cookies in crawler, this was switched on (by mistake)
This fix was needed for a case where a web server flooded the crawler with cookies and caused a complete blocking of the httpc.

git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@6043 6c8d7289-2bf4-0310-a012-ef5d649a1542
pull/1/head
orbiter 16 years ago
parent 1c54ae4a63
commit db3a06dd81

@ -165,7 +165,7 @@ public class httpClient {
private httpRemoteProxyConfig proxyConfig = null; private httpRemoteProxyConfig proxyConfig = null;
private boolean useGlobalProxyConfig = true; private boolean useGlobalProxyConfig = true;
private boolean followRedirects = true; private boolean followRedirects = true;
private boolean ignoreCookies = false; //private boolean ignoreCookies = true;
/** /**
* creates a new JakartaCommonsHttpClient with given timeout using global remoteProxyConfig * creates a new JakartaCommonsHttpClient with given timeout using global remoteProxyConfig
@ -241,19 +241,6 @@ public class httpClient {
followRedirects = follow; followRedirects = follow;
} }
/**
* <p>by default Cookies are accepted and used autmatically</p>
*
* <q cite="http://hc.apache.org/httpclient-3.x/cookies.html">HttpClient supports automatic management of cookies, including allowing the server to set cookies and
* automatically return them to the server when required.</q>
* <cite>HttpClient Cookie Guide</cite>
*
* @param ignoreCookies
*/
public void setIgnoreCookies(final boolean ignoreCookies) {
this.ignoreCookies = ignoreCookies;
}
/* /*
* (non-Javadoc) * (non-Javadoc)
* @see de.anomic.http.HttpClient#getUserAgent() * @see de.anomic.http.HttpClient#getUserAgent()
@ -272,6 +259,7 @@ public class httpClient {
public httpResponse GET(final String uri) throws IOException { public httpResponse GET(final String uri) throws IOException {
final HttpMethod get = new GetMethod(uri); final HttpMethod get = new GetMethod(uri);
get.setFollowRedirects(followRedirects); get.setFollowRedirects(followRedirects);
get.getParams().setCookiePolicy(CookiePolicy.IGNORE_COOKIES);
return execute(get); return execute(get);
} }
@ -286,6 +274,7 @@ public class httpClient {
assert uri != null : "precondition violated: uri != null"; assert uri != null : "precondition violated: uri != null";
final HttpMethod head = new HeadMethod(uri); final HttpMethod head = new HeadMethod(uri);
head.setFollowRedirects(followRedirects); head.setFollowRedirects(followRedirects);
head.getParams().setCookiePolicy(CookiePolicy.IGNORE_COOKIES);
return execute(head); return execute(head);
} }
@ -374,6 +363,7 @@ public class httpClient {
hostConfig.setHost(host, port); hostConfig.setHost(host, port);
final HttpMethod connect = new ConnectMethod(hostConfig); final HttpMethod connect = new ConnectMethod(hostConfig);
connect.setFollowRedirects(false); // there are no redirects possible for CONNECT commands as far as I know. connect.setFollowRedirects(false); // there are no redirects possible for CONNECT commands as far as I know.
connect.getParams().setCookiePolicy(CookiePolicy.IGNORE_COOKIES);
return execute(connect); return execute(connect);
} }
@ -437,7 +427,6 @@ public class httpClient {
*/ */
private httpResponse execute(final HttpMethod method) throws IOException { private httpResponse execute(final HttpMethod method) throws IOException {
assert method != null : "precondition violated: method != null"; assert method != null : "precondition violated: method != null";
checkIgnoreCookies(method);
setHeader(method); setHeader(method);
final httpRemoteProxyConfig hostProxyConfig = setProxy(method); final httpRemoteProxyConfig hostProxyConfig = setProxy(method);
@ -518,16 +507,6 @@ public class httpClient {
} }
} }
/**
* @param method
*/
private void checkIgnoreCookies(final HttpMethod method) {
// ignore cookies
if(ignoreCookies) {
method.getParams().setCookiePolicy(CookiePolicy.IGNORE_COOKIES);
}
}
/** /**
* @param method * @param method
* @return * @return

@ -1055,7 +1055,6 @@ public final class httpdProxyHandler {
final httpClient client = new httpClient(timeout, requestHeader); final httpClient client = new httpClient(timeout, requestHeader);
client.setFollowRedirects(false); client.setFollowRedirects(false);
// cookies are handled by the user's browser // cookies are handled by the user's browser
client.setIgnoreCookies(true);
client.setProxy(httpRemoteProxyConfig.getProxyConfigForURI(connectHost)); client.setProxy(httpRemoteProxyConfig.getProxyConfigForURI(connectHost));
return client; return client;
} }

Loading…
Cancel
Save