fixed Proxy (for GET, POST still does not work!)

git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@4665 6c8d7289-2bf4-0310-a012-ef5d649a1542
pull/1/head
danielr 17 years ago
parent 081ed1d3ec
commit 94d3d3a86f

@ -512,7 +512,7 @@ public final class httpdProxyHandler {
(!(remotePath.startsWith("/env"))) // this is the special path, staying always at root-level (!(remotePath.startsWith("/env"))) // this is the special path, staying always at root-level
) remotePath = yAddress.substring(pos) + remotePath; ) remotePath = yAddress.substring(pos) + remotePath;
prepareHeader(requestHeader, httpVer); prepareRequestHeader(requestHeader, httpVer);
// generate request-url // generate request-url
final String connectHost = (yAddress == null) ? host +":"+ port : yAddress; final String connectHost = (yAddress == null) ? host +":"+ port : yAddress;
@ -527,26 +527,27 @@ public final class httpdProxyHandler {
conProp.put(httpHeader.CONNECTION_PROP_CLIENT_REQUEST_HEADER,requestHeader); conProp.put(httpHeader.CONNECTION_PROP_CLIENT_REQUEST_HEADER,requestHeader);
// determine if it's an internal error of the httpc // determine if it's an internal error of the httpc
if (res.getResponseHeader().size() == 0) { final httpHeader responseHeader = res.getResponseHeader();
if (responseHeader.size() == 0) {
throw new Exception(res.getStatusLine()); throw new Exception(res.getStatusLine());
} }
// if the content length is not set we have to use chunked transfer encoding // if the content length is not set we have to use chunked transfer encoding
long contentLength = res.getResponseHeader().contentLength(); long contentLength = responseHeader.contentLength();
if (contentLength < 0) { if (contentLength < 0) {
// according to http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html // according to http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html
// a 204,304 message must not contain a message body. // a 204,304 message must not contain a message body.
// Therefore we need to set the content-length to 0. // Therefore we need to set the content-length to 0.
if (res.getStatusCode() == 204 || if (res.getStatusCode() == 204 ||
res.getStatusCode() == 304) { res.getStatusCode() == 304) {
res.getResponseHeader().put(httpHeader.CONTENT_LENGTH,"0"); responseHeader.put(httpHeader.CONTENT_LENGTH,"0");
} else { } else {
if (httpVer.equals(httpHeader.HTTP_VERSION_0_9) || httpVer.equals(httpHeader.HTTP_VERSION_1_0)) { if (httpVer.equals(httpHeader.HTTP_VERSION_0_9) || httpVer.equals(httpHeader.HTTP_VERSION_1_0)) {
conProp.setProperty(httpHeader.CONNECTION_PROP_PERSISTENT,"close"); conProp.setProperty(httpHeader.CONNECTION_PROP_PERSISTENT,"close");
} else { } else {
chunkedOut = new httpChunkedOutputStream(respond); chunkedOut = new httpChunkedOutputStream(respond);
} }
res.getResponseHeader().remove(httpHeader.CONTENT_LENGTH); responseHeader.remove(httpHeader.CONTENT_LENGTH);
} }
} }
@ -562,7 +563,7 @@ public final class httpdProxyHandler {
// reserver cache entry // reserver cache entry
Date requestDate = new Date(((Long)conProp.get(httpHeader.CONNECTION_PROP_REQUEST_START)).longValue()); Date requestDate = new Date(((Long)conProp.get(httpHeader.CONNECTION_PROP_REQUEST_START)).longValue());
IResourceInfo resInfo = new ResourceInfo(url,requestHeader,res.getResponseHeader()); IResourceInfo resInfo = new ResourceInfo(url,requestHeader,responseHeader);
plasmaHTCache.Entry cacheEntry = plasmaHTCache.newEntry( plasmaHTCache.Entry cacheEntry = plasmaHTCache.newEntry(
requestDate, requestDate,
0, 0,
@ -579,31 +580,27 @@ public final class httpdProxyHandler {
// handle file types and make (possibly transforming) output stream // handle file types and make (possibly transforming) output stream
if ( if (
(!transformer.isIdentityTransformer()) && (!transformer.isIdentityTransformer()) &&
(plasmaParser.supportedHTMLContent(url,res.getResponseHeader().mime())) (plasmaParser.supportedHTMLContent(url,responseHeader.mime()))
) { ) {
// make a transformer // make a transformer
theLogger.logFine("create transformer for URL " + url); theLogger.logFine("create transformer for URL " + url);
//hfos = new htmlFilterOutputStream((gzippedOut != null) ? gzippedOut : ((chunkedOut != null)? chunkedOut : respond), null, transformer, (ext.length() == 0)); //hfos = new htmlFilterOutputStream((gzippedOut != null) ? gzippedOut : ((chunkedOut != null)? chunkedOut : respond), null, transformer, (ext.length() == 0));
String charSet = httpHeader.getCharSet(res.getResponseHeader()); String charSet = httpHeader.getCharSet(responseHeader);
hfos = new htmlFilterWriter((gzippedOut != null) ? gzippedOut : ((chunkedOut != null)? chunkedOut : respond),charSet, null, transformer, (ext.length() == 0)); hfos = new htmlFilterWriter((gzippedOut != null) ? gzippedOut : ((chunkedOut != null)? chunkedOut : respond),charSet, null, transformer, (ext.length() == 0));
} else { } else {
// simply pass through without parsing // simply pass through without parsing
theLogger.logFine("create passthrough for URL " + url + ", extension '" + ext + "', mime-type '" + res.getResponseHeader().mime() + "'"); theLogger.logFine("create passthrough for URL " + url + ", extension '" + ext + "', mime-type '" + responseHeader.mime() + "'");
hfos = (gzippedOut != null) ? gzippedOut : ((chunkedOut != null)? chunkedOut : respond); hfos = (gzippedOut != null) ? gzippedOut : ((chunkedOut != null)? chunkedOut : respond);
} }
// handle incoming cookies // handle incoming cookies
handleIncomingCookies(res.getResponseHeader(), host, ip); handleIncomingCookies(responseHeader, host, ip);
// remove hop by hop headers prepareResponseHeader(responseHeader, res.getHttpVer());
removeHopByHopHeaders(res.getResponseHeader());
// adding additional headers
setViaHeader(res.getResponseHeader(), res.getHttpVer());
// sending the respond header back to the client // sending the respond header back to the client
if (chunkedOut != null) { if (chunkedOut != null) {
res.getResponseHeader().put(httpHeader.TRANSFER_ENCODING, "chunked"); responseHeader.put(httpHeader.TRANSFER_ENCODING, "chunked");
} }
httpd.sendRespondHeader( httpd.sendRespondHeader(
@ -612,7 +609,7 @@ public final class httpdProxyHandler {
httpVer, httpVer,
res.getStatusCode(), res.getStatusCode(),
res.getStatusLine().substring(4), // status text res.getStatusLine().substring(4), // status text
res.getResponseHeader()); responseHeader);
String storeError = cacheEntry.shallStoreCacheForProxy(); String storeError = cacheEntry.shallStoreCacheForProxy();
boolean storeHTCache = cacheEntry.profile().storeHTCache(); boolean storeHTCache = cacheEntry.profile().storeHTCache();
@ -752,7 +749,7 @@ public final class httpdProxyHandler {
// we respond on the request by using the cache, the cache is fresh // we respond on the request by using the cache, the cache is fresh
try { try {
prepareHeader(cachedResponseHeader, httpVer); prepareRequestHeader(cachedResponseHeader, httpVer);
// replace date field in old header by actual date, this is according to RFC // replace date field in old header by actual date, this is according to RFC
cachedResponseHeader.put(httpHeader.DATE, HttpClient.dateString(new Date())); cachedResponseHeader.put(httpHeader.DATE, HttpClient.dateString(new Date()));
@ -931,7 +928,7 @@ public final class httpdProxyHandler {
// attach possible yacy-sublevel-domain // attach possible yacy-sublevel-domain
if ((yAddress != null) && ((pos = yAddress.indexOf("/")) >= 0)) remotePath = yAddress.substring(pos) + remotePath; if ((yAddress != null) && ((pos = yAddress.indexOf("/")) >= 0)) remotePath = yAddress.substring(pos) + remotePath;
prepareHeader(requestHeader, httpVer); prepareRequestHeader(requestHeader, httpVer);
// setup HTTP-client // setup HTTP-client
HttpClient client = HttpFactory.newClient(); HttpClient client = HttpFactory.newClient();
@ -950,18 +947,15 @@ public final class httpdProxyHandler {
res = client.HEAD(getUrl); res = client.HEAD(getUrl);
// determine if it's an internal error of the httpc // determine if it's an internal error of the httpc
if (res.getResponseHeader().size() == 0) { final httpHeader responseHeader = res.getResponseHeader();
if (responseHeader.size() == 0) {
throw new Exception(res.getStatusLine()); throw new Exception(res.getStatusLine());
} }
// removing hop by hop headers prepareResponseHeader(responseHeader, res.getHttpVer());
removeHopByHopHeaders(res.getResponseHeader());
// adding outgoing headers
setViaHeader(res.getResponseHeader(), res.getHttpVer());
// sending the server respond back to the client // sending the server respond back to the client
httpd.sendRespondHeader(conProp,respond,httpVer,res.getStatusCode(),res.getStatusLine().substring(4),res.getResponseHeader()); httpd.sendRespondHeader(conProp,respond,httpVer,res.getStatusCode(),res.getStatusLine().substring(4),responseHeader);
respond.flush(); respond.flush();
} finally { } finally {
if(res != null) { if(res != null) {
@ -975,7 +969,6 @@ public final class httpdProxyHandler {
} }
public static void doPost(Properties conProp, httpHeader requestHeader, OutputStream respond, PushbackInputStream body) throws IOException { public static void doPost(Properties conProp, httpHeader requestHeader, OutputStream respond, PushbackInputStream body) throws IOException {
yacyURL url = null; yacyURL url = null;
try { try {
// remembering the starting time of the request // remembering the starting time of the request
@ -1027,7 +1020,7 @@ public final class httpdProxyHandler {
// attach possible yacy-sublevel-domain // attach possible yacy-sublevel-domain
if ((yAddress != null) && ((pos = yAddress.indexOf("/")) >= 0)) remotePath = yAddress.substring(pos) + remotePath; if ((yAddress != null) && ((pos = yAddress.indexOf("/")) >= 0)) remotePath = yAddress.substring(pos) + remotePath;
prepareHeader(requestHeader, httpVer); prepareRequestHeader(requestHeader, httpVer);
// setup HTTP-client // setup HTTP-client
JakartaCommonsHttpClient client = new JakartaCommonsHttpClient(); JakartaCommonsHttpClient client = new JakartaCommonsHttpClient();
@ -1043,16 +1036,17 @@ public final class httpdProxyHandler {
HttpResponse res = null; HttpResponse res = null;
try { try {
// sending the request // sending the request
// is the input stream required and valid HTTP-data? // TODO is the input stream required and valid HTTP-data?
res = client.POST(getUrl, body); res = client.POST(getUrl, body);
// determine if it's an internal error of the httpc // determine if it's an internal error of the httpc
if (res.getResponseHeader().size() == 0) { final httpHeader responseHeader = res.getResponseHeader();
if (responseHeader.size() == 0) {
throw new Exception(res.getStatusLine()); throw new Exception(res.getStatusLine());
} }
// if the content length is not set we need to use chunked content encoding // if the content length is not set we need to use chunked content encoding
long contentLength = res.getResponseHeader().contentLength(); long contentLength = responseHeader.contentLength();
httpChunkedOutputStream chunked = null; httpChunkedOutputStream chunked = null;
if (contentLength <= 0) { if (contentLength <= 0) {
// according to http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html // according to http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html
@ -1060,26 +1054,22 @@ public final class httpdProxyHandler {
// Therefore we need to set the content-length to 0. // Therefore we need to set the content-length to 0.
if (res.getStatusCode() == 204 || if (res.getStatusCode() == 204 ||
res.getStatusCode() == 304) { res.getStatusCode() == 304) {
res.getResponseHeader().put(httpHeader.CONTENT_LENGTH,"0"); responseHeader.put(httpHeader.CONTENT_LENGTH,"0");
} else { } else {
if (httpVer.equals("HTTP/0.9") || httpVer.equals("HTTP/1.0")) { if (httpVer.equals("HTTP/0.9") || httpVer.equals("HTTP/1.0")) {
forceConnectionClose(conProp); forceConnectionClose(conProp);
} else { } else {
chunked = new httpChunkedOutputStream(respond); chunked = new httpChunkedOutputStream(respond);
} }
res.getResponseHeader().remove(httpHeader.CONTENT_LENGTH); responseHeader.remove(httpHeader.CONTENT_LENGTH);
} }
} }
// remove hop by hop headers prepareResponseHeader(responseHeader, res.getHttpVer());
removeHopByHopHeaders(res.getResponseHeader());
// adding additional headers
setViaHeader(res.getResponseHeader(), res.getHttpVer());
// sending the respond header back to the client // sending the respond header back to the client
if (chunked != null) { if (chunked != null) {
res.getResponseHeader().put(httpHeader.TRANSFER_ENCODING, "chunked"); responseHeader.put(httpHeader.TRANSFER_ENCODING, "chunked");
} }
// sending response headers // sending response headers
@ -1088,7 +1078,7 @@ public final class httpdProxyHandler {
httpVer, httpVer,
res.getStatusCode(), res.getStatusCode(),
res.getStatusLine().substring(4), // status text res.getStatusLine().substring(4), // status text
res.getResponseHeader()); responseHeader);
// respondHeader(respond, res.status, res.responseHeader); // respondHeader(respond, res.status, res.responseHeader);
Saver.writeContent(res, (chunked != null) ? chunked : respond, null); Saver.writeContent(res, (chunked != null) ? chunked : respond, null);
@ -1114,6 +1104,26 @@ public final class httpdProxyHandler {
} }
} }
/**
* @param res
* @param responseHeader
*/
private static void prepareResponseHeader(final httpHeader responseHeader, final String httpVer) {
prepareRequestHeader(responseHeader, httpVer);
correctContentEncoding(responseHeader);
}
/**
* @param responseHeader
*/
private static void correctContentEncoding(final httpHeader responseHeader) {
// TODO gzip again? set "correct" encoding?
if(responseHeader.gzip()) {
responseHeader.remove(httpHeader.CONTENT_ENCODING);
}
}
/** /**
* adds the client-IP of conProp to the requestHeader * adds the client-IP of conProp to the requestHeader
* *
@ -1133,7 +1143,7 @@ public final class httpdProxyHandler {
* @param requestHeader * @param requestHeader
* @param httpVer * @param httpVer
*/ */
private static void prepareHeader(httpHeader requestHeader, String httpVer) { private static void prepareRequestHeader(final httpHeader requestHeader, final String httpVer) {
removeHopByHopHeaders(requestHeader); removeHopByHopHeaders(requestHeader);
setViaHeader(requestHeader, httpVer); setViaHeader(requestHeader, httpVer);
} }

Loading…
Cancel
Save