Ответ 1
imho: Apache HTTP Client
Пример использования:
import org.apache.commons.httpclient.*;
import org.apache.commons.httpclient.methods.*;
import org.apache.commons.httpclient.params.HttpMethodParams;
import java.io.*;
public class HttpClientTutorial {
private static String url = "http://www.apache.org/";
public static void main(String[] args) {
// Create an instance of HttpClient.
HttpClient client = new HttpClient();
// Create a method instance.
GetMethod method = new GetMethod(url);
// Provide custom retry handler is necessary
method.getParams().setParameter(HttpMethodParams.RETRY_HANDLER,
new DefaultHttpMethodRetryHandler(3, false));
try {
// Execute the method.
int statusCode = client.executeMethod(method);
if (statusCode != HttpStatus.SC_OK) {
System.err.println("Method failed: " + method.getStatusLine());
}
// Read the response body.
byte[] responseBody = method.getResponseBody();
// Deal with the response.
// Use caution: ensure correct character encoding and is not binary data
System.out.println(new String(responseBody));
} catch (HttpException e) {
System.err.println("Fatal protocol violation: " + e.getMessage());
e.printStackTrace();
} catch (IOException e) {
System.err.println("Fatal transport error: " + e.getMessage());
e.printStackTrace();
} finally {
// Release the connection.
method.releaseConnection();
}
}
}
некоторые основные функции:
- Стандартная, чистая Java, реализация HTTP версий 1.0
и 1.1
- Полная реализация всех HTTP-методов (GET, POST, PUT, DELETE, HEAD, OPTIONS и TRACE) в расширяемая структура OO.
- Поддерживает шифрование с протоколом HTTPS (HTTP over SSL).
- Конфигурация и отслеживание гранулированных нестандартных стандартов.
- Прозрачные соединения через HTTP-прокси.
- Туннелированные HTTPS-соединения через HTTP-прокси через CONNECT Метод.
- Прозрачные соединения через прокси SOCKS (версии 4 и 5) с использованием встроенная поддержка сокетов Java.
- Аутентификация с использованием Basic, Digest и шифрования NTLM (NT Lan Manager).
- Механизм подключаемого модуля для пользовательских методов проверки подлинности.
- Многопользовательская форма POST для загрузки больших файлов.
- Реализация подключаемых безопасных сокетов, упрощающая использовать сторонние решения.
- Поддержка управления соединением для использования в многопоточных Приложения. Поддерживает настройку максимальные общие соединения, а также максимальные соединения на хост. Обнаруживает и закрывает устаревшие соединения.
- Автоматическая обработка файлов cookie для чтения Set-Cookie: заголовки из сервера и отправить их обратно в Cookie: заголовок при необходимости.
- Механизм подключаемого модуля для пользовательских политик cookie.
- Запросить выходные потоки, чтобы избежать буферизации любого содержимого потоковая передача непосредственно в сокет сервер.
- Ответные входные потоки для эффективного считывания тела ответа потоковая передача непосредственно из сокета в сервер.
- Постоянные соединения с использованием KeepAlive в HTTP/1.0 и стойкость в HTTP/1.1
- Прямой доступ к коду ответа и заголовкам, отправленным сервером.
- Возможность устанавливать таймауты подключения.
- HttpMethods реализует шаблон команды, чтобы разрешить параллельную запросов и эффективного повторного использования соединения.
- Исходный код свободно доступен под лицензией программного обеспечения Apache.