You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
215 lines
6.0 KiB
215 lines
6.0 KiB
// HttpClient.java
|
|
// (C) 2008 by Daniel Raap; danielr@users.berlios.de
|
|
// first published 2.4.2008 on http://yacy.net
|
|
//
|
|
// This is a part of YaCy, a peer-to-peer based web search engine
|
|
//
|
|
// $LastChangedDate: 2008-03-14 01:16:04 +0100 (Fr, 14 Mrz 2008) $
|
|
// $LastChangedRevision: 4558 $
|
|
// $LastChangedBy: orbiter $
|
|
//
|
|
// LICENSE
|
|
//
|
|
// This program is free software; you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation; either version 2 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program; if not, write to the Free Software
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
package de.anomic.http;
|
|
|
|
import java.io.IOException;
|
|
import java.util.Date;
|
|
|
|
import de.anomic.server.logging.serverLog;
|
|
|
|
/**
|
|
* Client who does http requests
|
|
*
|
|
* some methods must be implemented (the "socket-layer")
|
|
*/
|
|
public abstract class HttpClient {
|
|
|
|
/**
|
|
* provide system information for client identification
|
|
*/
|
|
private static final String systemOST = System.getProperty("os.arch", "no-os-arch") + " " +
|
|
System.getProperty("os.name", "no-os-name") + " " + System.getProperty("os.version", "no-os-version") +
|
|
"; " + "java " + System.getProperty("java.version", "no-java-version") + "; " + generateLocation();
|
|
|
|
/**
|
|
* generating the location string
|
|
*
|
|
* @return
|
|
*/
|
|
public static String generateLocation() {
|
|
String loc = System.getProperty("user.timezone", "nowhere");
|
|
final int p = loc.indexOf("/");
|
|
if (p > 0) {
|
|
loc = loc.substring(0, p);
|
|
}
|
|
loc = loc + "/" + System.getProperty("user.language", "dumb");
|
|
return loc;
|
|
}
|
|
|
|
/**
|
|
* @return the systemOST
|
|
*/
|
|
public static String getSystemOST() {
|
|
return systemOST;
|
|
}
|
|
|
|
/**
|
|
* for easy access
|
|
*
|
|
* @see date2String(Date)
|
|
* @param date
|
|
* @return
|
|
*/
|
|
public static String dateString(final Date date) {
|
|
return JakartaCommonsHttpClient.date2String(date);
|
|
}
|
|
|
|
/**
|
|
* Gets a page (as raw bytes)
|
|
*
|
|
* @param uri
|
|
* @return
|
|
*/
|
|
public static byte[] wget(final String uri) {
|
|
return wget(uri, null, null);
|
|
}
|
|
|
|
/**
|
|
* Gets a page (as raw bytes) addressing vhost at host in uri
|
|
*
|
|
* @param uri
|
|
* @param vhost used if host in uri cannot be resolved (yacy tld)
|
|
* @return
|
|
*/
|
|
public static byte[] wget(final String uri, final String vhost) {
|
|
return wget(uri, null, vhost);
|
|
}
|
|
|
|
/**
|
|
* Gets a page (as raw bytes) aborting after timeout
|
|
*
|
|
* @param uri
|
|
* @param timeout in milliseconds
|
|
* @return
|
|
*/
|
|
public static byte[] wget(final String uri, final int timeout) {
|
|
return wget(uri, null, null, timeout);
|
|
}
|
|
|
|
/**
|
|
* Gets a page (as raw bytes) with specified header
|
|
*
|
|
* @param uri
|
|
* @param header
|
|
* @return
|
|
*/
|
|
public static byte[] wget(final String uri, final httpHeader header) {
|
|
return wget(uri, header, null);
|
|
}
|
|
|
|
/**
|
|
* Gets a page (as raw bytes) addressing vhost at host in uri with specified header
|
|
*
|
|
* @param uri
|
|
* @param header
|
|
* @param vhost
|
|
* @return
|
|
* @require uri != null
|
|
*/
|
|
public static byte[] wget(final String uri, final httpHeader header, final String vhost) {
|
|
return wget(uri, header, vhost, 10000);
|
|
}
|
|
|
|
/**
|
|
* Gets a page (as raw bytes) addressing vhost at host in uri with specified header and timeout
|
|
*
|
|
* @param uri
|
|
* @param header
|
|
* @param vhost
|
|
* @param timeout in milliseconds
|
|
* @return
|
|
*/
|
|
public static byte[] wget(final String uri, httpHeader header, final String vhost, final int timeout) {
|
|
assert uri != null : "precondition violated: uri != null";
|
|
final JakartaCommonsHttpClient client = new JakartaCommonsHttpClient(timeout, null, null);
|
|
|
|
// set header
|
|
header = addHostHeader(header, vhost);
|
|
client.setHeader(header);
|
|
|
|
// do the request
|
|
try {
|
|
final JakartaCommonsHttpResponse response = client.GET(uri);
|
|
return response.getData();
|
|
} catch (final IOException e) {
|
|
serverLog.logWarning("HTTPC", "wget(" + uri + ") failed: " + e.getMessage());
|
|
}
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* adds a Host-header to the header if vhost is not null
|
|
*
|
|
* @param header
|
|
* @param vhost
|
|
* @return
|
|
*/
|
|
private static httpHeader addHostHeader(httpHeader header, final String vhost) {
|
|
if (vhost != null) {
|
|
if (header != null) {
|
|
header = new httpHeader();
|
|
}
|
|
// set host-header
|
|
header.add(httpHeader.HOST, vhost);
|
|
}
|
|
return header;
|
|
}
|
|
|
|
/**
|
|
* Gets a page-header
|
|
*
|
|
* @param uri
|
|
* @return
|
|
*/
|
|
public static httpHeader whead(final String uri) {
|
|
return whead(uri, null);
|
|
}
|
|
|
|
/**
|
|
* Gets a page-header
|
|
*
|
|
* @param uri
|
|
* @param header request header
|
|
* @return
|
|
*/
|
|
public static httpHeader whead(final String uri, final httpHeader header) {
|
|
final JakartaCommonsHttpClient client = new JakartaCommonsHttpClient(10000, header, null);
|
|
JakartaCommonsHttpResponse response = null;
|
|
try {
|
|
response = client.HEAD(uri);
|
|
return response.getResponseHeader();
|
|
} catch (final IOException e) {
|
|
serverLog.logWarning("HTTPC", "whead(" + uri + ") failed: " + e.getMessage());
|
|
} finally {
|
|
if (response != null) {
|
|
response.closeStream();
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
}
|