Apache HttpClient - Краткое руководство
Протокол передачи гипертекста (HTTP) - это протокол прикладного уровня для распределенных, совместных гипермедийных информационных систем. Это основа для передачи данных во всемирной паутине (то есть в Интернете) с 1990 года. HTTP - это общий протокол без сохранения состояния, который можно использовать для других целей, а также с использованием расширений его методов запроса, кодов ошибок и заголовков.
По сути, HTTP - это протокол связи на основе TCP / IP, который используется для доставки данных (файлов HTML, файлов изображений, результатов запросов и т. Д.) Во всемирную паутину. Порт по умолчанию - TCP 80, но можно использовать и другие порты. Он обеспечивает стандартизированный способ взаимодействия компьютеров друг с другом. Спецификация HTTP определяет, как данные запросов клиентов будут создаваться и отправляться на сервер, и как серверы отвечают на эти запросы.
Что такое HTTP-клиент
Http-клиент - это библиотека передачи, она находится на стороне клиента, отправляет и получает сообщения HTTP. Он обеспечивает современную, многофункциональную и эффективную реализацию, соответствующую последним стандартам HTTP.
В дополнение к этому с использованием клиентской библиотеки можно создавать приложения на основе HTTP, такие как веб-браузеры, клиенты веб-служб и т. Д.
Особенности Http-клиента
Ниже приведены основные особенности Http-клиента.
Библиотека HttpClient реализует все доступные методы HTTP.
Библиотека HttpClient предоставляет API-интерфейсы для защиты запросов с использованием протокола Secure Socket Layer.
Используя HttpClient, вы можете устанавливать соединения с помощью прокси.
Вы можете аутентифицировать соединения, используя такие схемы аутентификации, как Basic, Digest, NTLMv1, NTLMv2, NTLM2 Session и т. Д.
Библиотека HttpClient поддерживает отправку запросов через несколько потоков. Он управляет несколькими соединениями, установленными из разных потоков, используяClientConnectionPoolManager.
Используя библиотеку Apache HttpClient, вы можете установить тайм-ауты подключения.
В этой главе мы объясним, как настроить среду для HttpClient в Eclipse IDE. Прежде чем продолжить установку, убедитесь, что в вашей системе уже установлен Eclipse. Если нет, загрузите и установите Eclipse.
Для получения дополнительной информации о Eclipse, пожалуйста, обратитесь к нашему учебному пособию по Eclipse .
Шаг 1 - Загрузите файл JAR зависимости
Откройте официальную домашнюю страницу сайта HttpClient (компоненты) и перейдите на страницу загрузки.
Затем загрузите последнюю стабильную версию HttpClient. Здесь на протяжении всего урока мы используем версию 4.5.6, поэтому загрузите файл4.5.6.zip.
В загруженной папке вы найдете папку с именем lib и он содержит необходимые файлы Jar, которые должны быть добавлены в путь к классам вашего проекта для работы с HttpClient.
Шаг 2 - Создайте проект и укажите путь сборки
Откройте eclipse и создайте образец проекта. Щелкните правой кнопкой мыши проект, выберите опциюBuild Path → Configure Build Path как показано ниже.
в Java Build Path кадр в Libraries вкладку, нажмите на Add External JARs.
И выберите все файлы jar в папке lib и нажмите Apply and Close.
Вы готовы к работе с библиотекой HttpClient в eclipse.
Метод GET используется для получения информации с заданного сервера с использованием заданного URI. Запросы, использующие GET, должны только извлекать данные и не должны иметь никакого другого влияния на данные.
API HttpClient предоставляет класс с именем HttpGet который представляет метод запроса на получение.
Следуйте инструкциям ниже, чтобы отправить запрос на получение с помощью библиотеки HttpClient.
Шаг 1. Создайте объект HttpClient
В createDefault() метод HttpClients класс возвращает CloseableHttpClient объект, который является базовой реализацией HttpClient интерфейс.
Используя этот метод, создайте объект HttpClient, как показано ниже -
CloseableHttpClient httpclient = HttpClients.createDefault();
Шаг 2 - Создайте объект HttpGet
В HttpGet class представляет запрос HTTPGET, который извлекает информацию о данном сервере с использованием URI.
Создайте HTTP-запрос GET, создав экземпляр этого класса. Конструктор этого класса принимает значение String, представляющее URI.
HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");
Шаг 3 - Выполните запрос на получение
В execute() метод CloseableHttpClient class принимает объект HttpUriRequest (интерфейс) (т.е. HttpGet, HttpPost, HttpPut, HttpHead и т. д.) и возвращает объект ответа.
Выполните запрос, используя этот метод, как показано ниже -
HttpResponse httpresponse = httpclient.execute(httpget);
пример
Ниже приведен пример, демонстрирующий выполнение запроса HTTP GET с использованием библиотеки HttpClient.
import java.util.Scanner;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
public class HttpGetExample {
public static void main(String args[]) throws Exception{
//Creating a HttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
//Creating a HttpGet object
HttpGet httpget = new HttpGet("https://www.tutorialspoint.com/ ");
//Printing the method used
System.out.println("Request Type: "+httpget.getMethod());
//Executing the Get request
HttpResponse httpresponse = httpclient.execute(httpget);
Scanner sc = new Scanner(httpresponse.getEntity().getContent());
//Printing the status line
System.out.println(httpresponse.getStatusLine());
while(sc.hasNext()) {
System.out.println(sc.nextLine());
}
}
}
Вывод
Вышеупомянутая программа генерирует следующий вывод -
Request Type: GET
<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<title>Parallax Scrolling, Java Cryptography, YAML, Python Data Science, Java
i18n, GitLab, TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible,
LOLCODE, Current Affairs 2018, Apache Commons Collections</title>
<meta name = "Description" content = "Parallax Scrolling, Java Cryptography, YAML,
Python Data Science, Java i18n, GitLab, TestRail, VersionOne, DBUtils, Common
CLI, Seaborn, Ansible, LOLCODE, Current Affairs 2018, Intellij Idea, Apache
Commons Collections, Java 9, GSON, TestLink, Inter Process Communication (IPC),
Logo, PySpark, Google Tag Manager, Free IFSC Code, SAP Workflow"/>
<meta name = "Keywords" content = "Python Data Science, Java i18n, GitLab,
TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible, LOLCODE, Gson,
TestLink, Inter Process Communication (IPC), Logo"/>
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href="/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
</script>
</body>
</html>
Запрос POST используется для отправки данных на сервер; например, информация о клиенте, загрузка файлов и т. д. с использованием HTML-форм.
API HttpClient предоставляет класс с именем HttpPost который представляет собой запрос POST.
Следуйте приведенным ниже инструкциям, чтобы отправить HTTP-запрос POST с помощью библиотеки HttpClient.
Шаг 1. Создайте объект HttpClient
В createDefault() метод HttpClients class возвращает объект класса CloseableHttpClient, которая является базовой реализацией HttpClient интерфейс.
Используя этот метод, создайте объект HttpClient.
CloseableHttpClient httpClient = HttpClients.createDefault();
Шаг 2 - Создайте объект HttpPost
В HttpPost класс представляет HTTP POSTзапрос. Это отправляет необходимые данные и извлекает информацию о данном сервере с помощью URI.
Создайте этот запрос, создав экземпляр HttpPost class и передайте строковое значение, представляющее URI, в качестве параметра его конструктору.
HttpGet httpGet = new HttpGet("http://www.tutorialspoint.com/");
Шаг 3 - Выполните запрос на получение
В execute() Метод объекта CloseableHttpClient принимает объект HttpUriRequest (interface) (т.е. HttpGet, HttpPost, HttpPut, HttpHead и т. д.) и возвращает объект ответа.
HttpResponse httpResponse = httpclient.execute(httpget);
пример
Ниже приведен пример, демонстрирующий выполнение запроса HTTP POST с использованием библиотеки HttpClient.
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
public class HttpPostExample {
public static void main(String args[]) throws Exception{
//Creating a HttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
//Creating a HttpGet object
HttpPost httppost = new HttpPost("https://www.tutorialspoint.com/");
//Printing the method used
System.out.println("Request Type: "+httppost.getMethod());
//Executing the Get request
HttpResponse httpresponse = httpclient.execute(httppost);
Scanner sc = new Scanner(httpresponse.getEntity().getContent());
//Printing the status line
System.out.println(httpresponse.getStatusLine());
while(sc.hasNext()) {
System.out.println(sc.nextLine());
}
}
}
Вывод
Вышеупомянутая программа генерирует следующий вывод.
Request Type: POST
<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<title>Parallax Scrolling, Java Cryptography, YAML, Python Data Science, Java
i18n, GitLab, TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible,
LOLCODE, Current Affairs 2018, Apache Commons Collections</title>
<meta name = "Description" content = "Parallax Scrolling, Java Cryptography, YAML,
Python Data Science, Java i18n, GitLab, TestRail, VersionOne, DBUtils, Common
CLI, Seaborn, Ansible, LOLCODE, Current Affairs 2018, Intellij Idea, Apache
Commons Collections, Java 9, GSON, TestLink, Inter Process Communication (IPC),
Logo, PySpark, Google Tag Manager, Free IFSC Code, SAP Workflow"/>
<meta name = "Keywords" content="Python Data Science, Java i18n, GitLab,
TestRail, VersionOne, DBUtils, Common CLI, Seaborn, Ansible, LOLCODE, Gson,
TestLink, Inter Process Communication (IPC), Logo"/>
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" conten t= "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href = "/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . .
</script>
</body>
</html>
Рекомендуется обрабатывать ответы HTTP с помощью обработчиков ответов. В этой главе мы собираемся обсудить, как создавать обработчики ответов и как их использовать для обработки ответа.
Если вы используете обработчик ответа, все HTTP-соединения будут освобождены автоматически.
Создание обработчика ответа
HttpClient API предоставляет интерфейс, известный как ResponseHandler в пакете org.apache.http.client. Чтобы создать обработчик ответа, реализуйте этот интерфейс и переопределите его handleResponse() метод.
Каждый ответ имеет код состояния, и если код состояния находится в диапазоне от 200 до 300, это означает, что действие было успешно получено, понято и принято. Следовательно, в нашем примере мы будем обрабатывать сущности ответов с такими кодами состояния.
Выполнение запроса с использованием обработчика ответа
Следуйте инструкциям ниже, чтобы выполнить запрос с помощью обработчика ответа.
Шаг 1. Создайте объект HttpClient
В createDefault() метод HttpClients class возвращает объект класса CloseableHttpClient, которая является базовой реализацией HttpClientинтерфейс. Используя этот метод, создайте объект HttpClient
CloseableHttpClient httpclient = HttpClients.createDefault();
Шаг 2 - Создайте экземпляр обработчика ответа
Создайте экземпляр объекта обработчика ответа, созданного выше, используя следующую строку кода -
ResponseHandler<String> responseHandler = new MyResponseHandler();
Шаг 3 - Создайте объект HttpGet
В HttpGet Класс представляет HTTP-запрос GET, который извлекает информацию о данном сервере с использованием URI.
Создайте запрос HttpGet, создав экземпляр класса HttpGet и передав строку, представляющую URI, в качестве параметра его конструктору.
ResponseHandler<String> responseHandler = new MyResponseHandler();
Шаг 4 - Выполните запрос Get с помощью обработчика ответа
В CloseableHttpClient класс имеет вариант execute() метод, который принимает два объекта ResponseHandler и HttpUriRequest и возвращает объект ответа.
String httpResponse = httpclient.execute(httpget, responseHandler);
пример
В следующем примере демонстрируется использование обработчиков ответов.
import java.io.IOException;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ResponseHandler;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
class MyResponseHandler implements ResponseHandler<String>{
public String handleResponse(final HttpResponse response) throws IOException{
//Get the status of the response
int status = response.getStatusLine().getStatusCode();
if (status >= 200 && status < 300) {
HttpEntity entity = response.getEntity();
if(entity == null) {
return "";
} else {
return EntityUtils.toString(entity);
}
} else {
return ""+status;
}
}
}
public class ResponseHandlerExample {
public static void main(String args[]) throws Exception{
//Create an HttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
//instantiate the response handler
ResponseHandler<String> responseHandler = new MyResponseHandler();
//Create an HttpGet object
HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");
//Execute the Get request by passing the response handler object and HttpGet object
String httpresponse = httpclient.execute(httpget, responseHandler);
System.out.println(httpresponse);
}
}
Вывод
Вышеупомянутые программы генерируют следующий вывод -
<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href = "/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'UA-232293-17');
</script>
</body>
Если вы обрабатываете HTTP-ответы вручную, а не используете обработчик ответов, вам необходимо закрыть все HTTP-соединения самостоятельно. В этой главе объясняется, как закрыть соединения вручную.
При закрытии HTTP-соединений вручную следуйте инструкциям ниже -
Шаг 1. Создайте объект HttpClient
В createDefault() метод HttpClients class возвращает объект класса CloseableHttpClient, который является базовой реализацией интерфейса HttpClient.
Используя этот метод, создайте HttpClient объект, как показано ниже -
CloseableHttpClient httpClient = HttpClients.createDefault();
Шаг 2 - Запустите блок попытки
Запустите блок try-finally, напишите оставшийся код в программах в блоке try и закройте объект CloseableHttpClient в блоке finally.
CloseableHttpClient httpClient = HttpClients.createDefault();
try{
//Remaining code . . . . . . . . . . . . . . .
}finally{
httpClient.close();
}
Шаг 3 - Создайте HttpGetobject
В HttpGet Класс представляет HTTP-запрос GET, который извлекает информацию о данном сервере с использованием URI.
Создайте запрос HTTP GET, создав экземпляр класса HttpGet, передав строку, представляющую URI.
HttpGet httpGet = new HttpGet("http://www.tutorialspoint.com/");
Шаг 4 - Выполните запрос Get
В execute() метод CloseableHttpClient объект принимает HttpUriRequest (интерфейс) объект (то есть HttpGet, HttpPost, HttpPut, HttpHead и т. д.) и возвращает объект ответа.
Выполните запрос, используя данный метод -
HttpResponse httpResponse = httpclient.execute(httpGet);
Шаг 5 - Начните еще одну (вложенную) попытку-наконец
Запустите другой блок try-finally (вложенный в предыдущий блок try-finally), напишите оставшийся код в программах в этом блоке try и закройте объект HttpResponse в блоке finally.
CloseableHttpClient httpclient = HttpClients.createDefault();
try{
. . . . . . .
. . . . . . .
CloseableHttpResponse httpresponse = httpclient.execute(httpget);
try{
. . . . . . .
. . . . . . .
}finally{
httpresponse.close();
}
}finally{
httpclient.close();
}
пример
Всякий раз, когда вы создаете / получаете объекты, такие как запрос, поток ответа и т. Д., Запустите блок try finally в следующей строке, напишите оставшийся код в try и закройте соответствующий объект в блоке finally, как показано в следующей программе:
import java.util.Scanner;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
public class CloseConnectionExample {
public static void main(String args[])throws Exception{
//Create an HttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
try{
//Create an HttpGet object
HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");
//Execute the Get request
CloseableHttpResponse httpresponse = httpclient.execute(httpget);
try{
Scanner sc = new Scanner(httpresponse.getEntity().getContent());
while(sc.hasNext()) {
System.out.println(sc.nextLine());
}
}finally{
httpresponse.close();
}
}finally{
httpclient.close();
}
}
}
Вывод
При выполнении вышеуказанной программы создается следующий вывод:
<!DOCTYPE html>
<!--[if IE 8]><html class = "ie ie8"> <![endif]-->
<!--[if IE 9]><html class = "ie ie9"> <![endif]-->
<!--[if gt IE 9]><!-->
<html lang = "en-US"> <!--<![endif]-->
<head>
<!-- Basic -->
<meta charset = "utf-8">
<meta http-equiv = "X-UA-Compatible" content = "IE = edge">
<meta name = "viewport" content = "width = device-width,initial-scale = 1.0,userscalable = yes">
<link href = "https://cdn.muicss.com/mui-0.9.39/extra/mui-rem.min.css"
rel = "stylesheet" type = "text/css" />
<link rel = "stylesheet" href = "/questions/css/home.css?v = 3" />
<script src = "/questions/js/jquery.min.js"></script>
<script src = "/questions/js/fontawesome.js"></script>
<script src = "https://cdn.muicss.com/mui-0.9.39/js/mui.min.js"></script>
</head>
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . .
<script>
window.dataLayer = window.dataLayer || [];
function gtag() {dataLayer.push(arguments);}
gtag('js', new Date());
gtag('config', 'UA-232293-17');
</script>
</body>
</html>
Вы можете прервать текущий HTTP-запрос, используя abort() метод, т. е. после вызова этого метода по определенному запросу выполнение его будет прервано.
Если этот метод вызывается после одного выполнения, ответы этого выполнения не будут затронуты, и последующие выполнения будут прерваны.
пример
Если вы наблюдаете следующий пример, мы создали запрос HttpGet, распечатали используемый формат запроса, используя getMethod().
Затем мы выполнили еще одно выполнение с тем же запросом. Распечатал строку состояния снова, используя 1- е выполнение. Наконец, распечатал строку состояния второго выполнения.
Как обсуждалось, ответы 1- го выполнения (выполнение до метода прерывания) печатаются (включая вторую строку состояния, которая записывается после метода прерывания), и все последующие исполнения текущего запроса после метода прерывания не выполняются, вызывая исключение.
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
public class HttpGetExample {
public static void main(String args[]) throws Exception{
//Creating an HttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
//Creating an HttpGet object
HttpGet httpget = new HttpGet("http://www.tutorialspoint.com/");
//Printing the method used
System.out.println(httpget.getMethod());
//Executing the Get request
HttpResponse httpresponse = httpclient.execute(httpget);
//Printing the status line
System.out.println(httpresponse.getStatusLine());
httpget.abort();
System.out.println(httpresponse.getEntity().getContentLength());
//Executing the Get request
HttpResponse httpresponse2 = httpclient.execute(httpget);
System.out.println(httpresponse2.getStatusLine());
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод:
On executing, the above program generates the following output.
GET
HTTP/1.1 200 OK
-1
Exception in thread "main" org.apache.http.impl.execchain.RequestAbortedException:
Request aborted
at org.apache.http.impl.execchain.MainClientExec.execute(MainClientExec.java:180)
at org.apache.http.impl.execchain.ProtocolExec.execute(ProtocolExec.java:185)
at org.apache.http.impl.execchain.RetryExec.execute(RetryExec.java:89)
at org.apache.http.impl.execchain.RedirectExec.execute(RedirectExec.java:110)
at org.apache.http.impl.client.InternalHttpClient.doExecute(InternalHttpClient.java:185)
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:83)
at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:108)
at HttpGetExample.main(HttpGetExample.java:32)
Перехватчики - это те, которые помогают блокировать или изменять запросы или ответы. Перехватчики протокола обычно действуют на определенный заголовок или группу связанных заголовков. Библиотека HttpClient обеспечивает поддержку перехватчиков.
Запросить перехватчик
В HttpRequestInterceptorинтерфейс представляет собой перехватчики запросов. Этот интерфейс содержит метод, известный как процесс, в котором вам нужно написать кусок кода для перехвата запросов.
На стороне клиента этот метод проверяет / обрабатывает запросы перед их отправкой на сервер, а на стороне сервера этот метод выполняется до оценки тела запроса.
Создание перехватчика запросов
Вы можете создать перехватчик запросов, выполнив действия, указанные ниже.
Step 1 - Create an object of HttpRequestInterceptor
Создайте объект интерфейса HttpRequestInterceptor, реализовав его абстрактный метод процесса.
HttpRequestInterceptor requestInterceptor = new HttpRequestInterceptor() {
@Override
public void process(HttpRequest request, HttpContext context) throws
HttpException, IOException {
//Method implementation . . . . .
};
Step 2 - Instantiate CloseableHttpClient object
Создать кастом CloseableHttpClient объект, добавив к нему созданный выше перехватчик, как показано ниже -
//Creating a CloseableHttpClient object
CloseableHttpClient httpclient =
HttpClients.custom().addInterceptorFirst(requestInterceptor).build();
Используя этот объект, вы можете выполнять запросы как обычно.
пример
Следующий пример демонстрирует использование перехватчиков запросов. В этом примере мы создали объект запроса HTTP GET и добавили к нему три заголовка: sample-header, demoheader и test-header.
в processor()метод перехватчика, мы проверяем заголовки отправленного запроса; если какой-либо из этих заголовковsample-header, мы пытаемся удалить его и отобразить список заголовков этого конкретного запроса.
import java.io.IOException;
import org.apache.http.Header;
import org.apache.http.HttpException;
import org.apache.http.HttpRequest;
import org.apache.http.HttpRequestInterceptor;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.message.BasicHeader;
import org.apache.http.protocol.HttpContext;
public class InterceptorsExample {
public static void main(String args[]) throws Exception{
//Creating an HttpRequestInterceptor
HttpRequestInterceptor requestInterceptor = new HttpRequestInterceptor() {
@Override
public void process(HttpRequest request, HttpContext context) throws
HttpException, IOException {
if(request.containsHeader("sample-header")) {
System.out.println("Contains header sample-header, removing it..");
request.removeHeaders("sample-header");
}
//Printing remaining list of headers
Header[] headers= request.getAllHeaders();
for (int i = 0; i<headers.length;i++) {
System.out.println(headers[i].getName());
}
}
};
//Creating a CloseableHttpClient object
CloseableHttpClient httpclient =
HttpClients.custom().addInterceptorFirst(requestInterceptor).build();
//Creating a request object
HttpGet httpget1 = new HttpGet("https://www.tutorialspoint.com/");
//Setting the header to it
httpget1.setHeader(new BasicHeader("sample-header","My first header"));
httpget1.setHeader(new BasicHeader("demo-header","My second header"));
httpget1.setHeader(new BasicHeader("test-header","My third header"));
//Executing the request
HttpResponse httpresponse = httpclient.execute(httpget1);
//Printing the status line
System.out.println(httpresponse.getStatusLine());
}
}
Вывод
При выполнении вышеуказанной программы создается следующий вывод:
Contains header sample-header, removing it..
demo-header
test-header
HTTP/1.1 200 OK
Перехватчик ответа
В HttpResponseInterceptorинтерфейс представляет собой перехватчики ответа. Этот интерфейс содержит метод, известный какprocess(). В этом методе вам нужно написать кусок кода для перехвата ответов.
На стороне сервера этот метод проверяет / обрабатывает ответ перед отправкой его клиенту, а на стороне клиента этот метод выполняется до оценки тела ответа.
Создание перехватчика ответа
Вы можете создать перехватчик ответа, выполнив следующие шаги:
Step 1 - Create an object of HttpResponseInterceptor
Создайте объект HttpResponseInterceptor интерфейс, реализовав его абстрактный метод process.
HttpResponseInterceptor responseInterceptor = new HttpResponseInterceptor() {
@Override
public void process(HttpResponse response, HttpContext context) throws HttpException, IOException {
//Method implementation . . . . . . . .
}
};
Шаг 2. Создайте экземпляр объекта CloseableHttpClient
Создать кастом CloseableHttpClient объект, добавив к нему созданный выше перехватчик, как показано ниже -
//Creating a CloseableHttpClient object
CloseableHttpClient httpclient =
HttpClients.custom().addInterceptorFirst(responseInterceptor).build();
Используя этот объект, вы можете выполнять запросы как обычно.
пример
В следующем примере демонстрируется использование перехватчиков ответа. В этом примере мы добавили три заголовка: sample-header, demo-header и test-header к ответу в процессоре.
После выполнения запроса и получения ответа мы распечатали имена всех заголовков ответа, используя getAllHeaders() метод.
И в выводе вы можете наблюдать названия трех заголовков в списке.
import java.io.IOException;
import org.apache.http.Header;
import org.apache.http.HttpException;
import org.apache.http.HttpResponse;
import org.apache.http.HttpResponseInterceptor;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.protocol.HttpContext;
public class ResponseInterceptorsExample {
public static void main(String args[]) throws Exception{
//Creating an HttpRequestInterceptor
HttpResponseInterceptor responseInterceptor = new HttpResponseInterceptor() {
@Override
public void process(HttpResponse response, HttpContext context) throws
HttpException, IOException {
System.out.println("Adding header sample_header, demo-header, test_header to the response");
response.setHeader("sample-header", "My first header");
response.setHeader("demo-header", "My second header");
response.setHeader("test-header", "My third header");
}
};
//Creating a CloseableHttpClient object
CloseableHttpClient httpclient = HttpClients.custom().addInterceptorFirst(responseInterceptor).build();
//Creating a request object
HttpGet httpget1 = new HttpGet("https://www.tutorialspoint.com/");
//Executing the request
HttpResponse httpresponse = httpclient.execute(httpget1);
//Printing remaining list of headers
Header[] headers = httpresponse.getAllHeaders();
for (int i = 0; i<headers.length;i++) {
System.out.println(headers[i].getName());
}
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий результат -
On executing the above program generates the following output.
Adding header sample_header, demo-header, test_header to the response
Accept-Ranges
Access-Control-Allow-Headers
Access-Control-Allow-Origin
Cache-Control
Content-Type
Date
Expires
Last-Modified
Server
Vary
X-Cache
sample-header
demo-header
test-header
Используя HttpClient, вы можете подключиться к веб-сайту, для которого требуется имя пользователя и пароль. В этой главе объясняется, как выполнить клиентский запрос к сайту, который запрашивает имя пользователя и пароль.
Шаг 1. Создайте объект CredentialsProvider
В CredentialsProviderИнтерфейс поддерживает коллекцию для хранения учетных данных пользователя. Вы можете создать его объект, создав экземплярBasicCredentialsProvider class, реализация этого интерфейса по умолчанию.
CredentialsProvider credentialsPovider = new BasicCredentialsProvider();
Шаг 2 - Установите учетные данные
Вы можете установить необходимые учетные данные для объекта CredentialsProvider с помощью setCredentials() метод.
Этот метод принимает два объекта, как указано ниже -
AuthScope object - Объем аутентификации с указанием таких деталей, как имя хоста, номер порта и имя схемы аутентификации.
Credentials object - Указание учетных данных (имя пользователя, пароль).
Установите учетные данные с помощью setCredentials() как для хоста, так и для прокси, как показано ниже -
credsProvider.setCredentials(new AuthScope("example.com", 80),
new UsernamePasswordCredentials("user", "mypass"));
credsProvider.setCredentials(new AuthScope("localhost", 8000),
new UsernamePasswordCredentials("abc", "passwd"));
Шаг 3 - Создайте объект HttpClientBuilder
Создать HttpClientBuilder используя custom() метод HttpClients класс.
//Creating the HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();
Шаг 4 - Установите учетные данные
Вы можете установить созданный выше объект credentialsPovider в HttpClientBuilder, используя setDefaultCredentialsProvider() метод.
Установите объект CredentialProvider, созданный на предыдущем шаге, в построитель клиента, передав его в CredentialsProvider object() метод, как показано ниже.
clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);
Шаг 5 - Создайте CloseableHttpClient
Построить CloseableHttpClient объект с помощью build() метод HttpClientBuilder класс.
CloseableHttpClient httpclient = clientbuilder.build()
Шаг 6 - Создайте объект HttpGet и выполните его
Создайте объект HttpRequest, создав экземпляр класса HttpGet. Выполните этот запрос, используяexecute() метод.
//Creating a HttpGet object
HttpGet httpget = new HttpGet("https://www.tutorialspoint.com/ ");
//Executing the Get request
HttpResponse httpresponse = httpclient.execute(httpget);
пример
Ниже приводится пример программы, демонстрирующей выполнение HTTP-запроса к целевому сайту, требующему аутентификации пользователя.
import org.apache.http.Header;
import org.apache.http.HttpResponse;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.Credentials;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
public class UserAuthenticationExample {
public static void main(String args[]) throws Exception{
//Create an object of credentialsProvider
CredentialsProvider credentialsPovider = new BasicCredentialsProvider();
//Set the credentials
AuthScope scope = new AuthScope("https://www.tutorialspoint.com/questions/", 80);
Credentials credentials = new UsernamePasswordCredentials("USERNAME", "PASSWORD");
credentialsPovider.setCredentials(scope,credentials);
//Creating the HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();
//Setting the credentials
clientbuilder = clientbuilder.setDefaultCredentialsProvider(credentialsPovider);
//Building the CloseableHttpClient object
CloseableHttpClient httpclient = clientbuilder.build();
//Creating a HttpGet object
HttpGet httpget = new HttpGet("https://www.tutorialspoint.com/questions/index.php");
//Printing the method used
System.out.println(httpget.getMethod());
//Executing the Get request
HttpResponse httpresponse = httpclient.execute(httpget);
//Printing the status line
System.out.println(httpresponse.getStatusLine());
int statusCode = httpresponse.getStatusLine().getStatusCode();
System.out.println(statusCode);
Header[] headers= httpresponse.getAllHeaders();
for (int i = 0; i<headers.length;i++) {
System.out.println(headers[i].getName());
}
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод.
GET
HTTP/1.1 200 OK
200
Прокси-сервер - это промежуточный сервер между клиентом и Интернетом. Прокси-серверы предлагают следующие основные функции -
Межсетевой экран и фильтрация сетевых данных
Совместное использование сетевого подключения
Кеширование данных
Используя библиотеку HttpClient, вы можете отправить HTTP-запрос через прокси. Следуйте инструкциям ниже -
Шаг 1. Создайте объект HttpHost
Создайте экземпляр HttpHost класс org.apache.http package, передав строковый параметр, представляющий имя прокси-хоста (с которого вам нужно отправлять запросы) его конструктору.
//Creating an HttpHost object for proxy
HttpHost proxyHost = new HttpHost("localhost");
Таким же образом создайте еще один объект HttpHost для представления целевого хоста, на который нужно отправлять запросы.
//Creating an HttpHost object for target
HttpHost targetHost = new HttpHost("google.com");
Шаг 2. Создайте объект HttpRoutePlanner
В HttpRoutePlannerинтерфейс вычисляет маршрут к указанному хосту. Создайте объект этого интерфейса, создав экземплярDefaultProxyRoutePlannerclass, реализация этого интерфейса. В качестве параметра его конструктору передайте созданный выше прокси-хост -
//creating a RoutePlanner object
HttpRoutePlanner routePlanner = new DefaultProxyRoutePlanner(proxyhost);
Шаг 3 - Установите планировщик маршрута на построитель клиента
Используя custom() метод HttpClients класс, создайте HttpClientBuilder объект и для этого объекта установите планировщик маршрута, созданный выше, используя setRoutePlanner() метод.
//Setting the route planner to the HttpClientBuilder object
HttpClientBuilder clientBuilder = HttpClients.custom();
clientBuilder = clientBuilder.setRoutePlanner(routePlanner);
Шаг 4 - Создайте объект CloseableHttpClient
Построить CloseableHttpClient объект, вызвав build() метод.
//Building a CloseableHttpClient
CloseableHttpClient httpClient = clientBuilder.build();
Шаг 5 - Создайте HttpGetobject
Создайте HTTP-запрос GET, создав экземпляр HttpGet класс.
//Creating an HttpGet object
HttpGet httpGet = new HttpGet("/");
Шаг 6 - Выполните запрос
Один из вариантов execute() метод принимает HttpHost и HttpRequestобъекты и выполняет запрос. Выполните запрос, используя этот метод -
//Executing the Get request
HttpResponse httpResponse = httpclient.execute(targetHost, httpGet);
пример
В следующем примере показано, как отправить HTTP-запрос на сервер через прокси. В этом примере мы отправляем HTTP-запрос GET на google.com через localhost. Мы распечатали заголовки ответа и тело ответа.
import org.apache.http.Header;
import org.apache.http.HttpEntity;
import org.apache.http.HttpHost;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.conn.routing.HttpRoutePlanner;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.DefaultProxyRoutePlanner;
import org.apache.http.util.EntityUtils;
public class RequestViaProxyExample {
public static void main(String args[]) throws Exception{
//Creating an HttpHost object for proxy
HttpHost proxyhost = new HttpHost("localhost");
//Creating an HttpHost object for target
HttpHost targethost = new HttpHost("google.com");
//creating a RoutePlanner object
HttpRoutePlanner routePlanner = new DefaultProxyRoutePlanner(proxyhost);
//Setting the route planner to the HttpClientBuilder object
HttpClientBuilder clientBuilder = HttpClients.custom();
clientBuilder = clientBuilder.setRoutePlanner(routePlanner);
//Building a CloseableHttpClient
CloseableHttpClient httpclient = clientBuilder.build();
//Creating an HttpGet object
HttpGet httpget = new HttpGet("/");
//Executing the Get request
HttpResponse httpresponse = httpclient.execute(targethost, httpget);
//Printing the status line
System.out.println(httpresponse.getStatusLine());
//Printing all the headers of the response
Header[] headers = httpresponse.getAllHeaders();
for (int i = 0; i < headers.length; i++) {
System.out.println(headers[i]);
}
//Printing the body of the response
HttpEntity entity = httpresponse.getEntity();
if (entity != null) {
System.out.println(EntityUtils.toString(entity));
}
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод:
HTTP/1.1 200 OK
Date: Sun, 23 Dec 2018 10:21:47 GMT
Server: Apache/2.4.9 (Win64) PHP/5.5.13
Last-Modified: Tue, 24 Jun 2014 10:46:24 GMT
ETag: "2e-4fc92abc3c000"
Accept-Ranges: bytes
Content-Length: 46
Content-Type: text/html
<html><body><h1>It works!</h1></body></html>
В этой главе мы узнаем, как создать HttpRequest, аутентифицированный с использованием имени пользователя и пароля, и туннелировать его через прокси на целевой хост, используя пример.
Шаг 1. Создайте объект CredentialsProvider
Интерфейс CredentialsProvider поддерживает коллекцию для хранения учетных данных пользователя. Вы можете создать его объект, создав экземпляр класса BasicCredentialsProvider, реализации этого интерфейса по умолчанию.
CredentialsProvider credentialsPovider = new BasicCredentialsProvider();
Шаг 2 - Установите учетные данные
Вы можете установить необходимые учетные данные для объекта CredentialsProvider с помощью setCredentials()метод. Этот метод принимает два объекта -
AuthScope object - Объем аутентификации с указанием таких деталей, как имя хоста, номер порта и имя схемы аутентификации.
Credentials object- Указание учетных данных (имя пользователя, пароль). Установите учетные данные с помощьюsetCredentials() как для хоста, так и для прокси, как показано ниже.
credsProvider.setCredentials(new AuthScope("example.com", 80), new
UsernamePasswordCredentials("user", "mypass"));
credsProvider.setCredentials(new AuthScope("localhost", 8000), new
UsernamePasswordCredentials("abc", "passwd"));
Шаг 3 - Создайте объект HttpClientBuilder
Создать HttpClientBuilder используя custom() метод HttpClients класс, как показано ниже -
//Creating the HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();
Шаг 4 - Установите CredentialsProvider
Вы можете установить объект CredentialsProvider на объект HttpClientBuilder, используя setDefaultCredentialsProvider()метод. Передайте ранее созданныйCredentialsProvider возражать против этого метода.
clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);
Шаг 5 - Создайте CloseableHttpClient
Построить CloseableHttpClient объект с помощью build() метод.
CloseableHttpClient httpclient = clientbuilder.build();
Шаг 6 - Создайте прокси и целевые хосты
Создайте целевой и прокси-хосты, создав экземпляр HttpHost класс.
//Creating the target and proxy hosts
HttpHost target = new HttpHost("example.com", 80, "http");
HttpHost proxy = new HttpHost("localhost", 8000, "http");
Шаг 7. Установите прокси и создайте объект RequestConfig.
Создать RequestConfig.Builder объект с помощью custom()метод. Установите для ранее созданного объекта proxyHost значениеRequestConfig.Builder используя setProxy()метод. Наконец, создайтеRequestConfig объект с помощью build() метод.
RequestConfig.Builder reqconfigconbuilder= RequestConfig.custom();
reqconfigconbuilder = reqconfigconbuilder.setProxy(proxyHost);
RequestConfig config = reqconfigconbuilder.build();
Шаг 8 - Создайте объект запроса HttpGet и установите для него объект конфигурации.
Создать HttpGetобъект, создав экземпляр класса HttpGet. Установите объект конфигурации, созданный на предыдущем шаге, для этого объекта, используяsetConfig() метод.
//Create the HttpGet request object
HttpGet httpGet = new HttpGet("/");
//Setting the config to the request
httpget.setConfig(config);
Шаг 9 - Выполните запрос
Выполните запрос, передав объект HttpHost (цель) и запрос (HttpGet) в качестве параметров в execute() метод.
HttpResponse httpResponse = httpclient.execute(targetHost, httpget);
пример
В следующем примере показано, как выполнить HTTP-запрос через прокси, используя имя пользователя и пароль.
import org.apache.http.HttpHost;
import org.apache.http.HttpResponse;
import org.apache.http.auth.AuthScope;
import org.apache.http.auth.UsernamePasswordCredentials;
import org.apache.http.client.CredentialsProvider;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.BasicCredentialsProvider;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
public class ProxyAuthenticationExample {
public static void main(String[] args) throws Exception {
//Creating the CredentialsProvider object
CredentialsProvider credsProvider = new BasicCredentialsProvider();
//Setting the credentials
credsProvider.setCredentials(new AuthScope("example.com", 80),
new UsernamePasswordCredentials("user", "mypass"));
credsProvider.setCredentials(new AuthScope("localhost", 8000),
new UsernamePasswordCredentials("abc", "passwd"));
//Creating the HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();
//Setting the credentials
clientbuilder = clientbuilder.setDefaultCredentialsProvider(credsProvider);
//Building the CloseableHttpClient object
CloseableHttpClient httpclient = clientbuilder.build();
//Create the target and proxy hosts
HttpHost targetHost = new HttpHost("example.com", 80, "http");
HttpHost proxyHost = new HttpHost("localhost", 8000, "http");
//Setting the proxy
RequestConfig.Builder reqconfigconbuilder= RequestConfig.custom();
reqconfigconbuilder = reqconfigconbuilder.setProxy(proxyHost);
RequestConfig config = reqconfigconbuilder.build();
//Create the HttpGet request object
HttpGet httpget = new HttpGet("/");
//Setting the config to the request
httpget.setConfig(config);
//Printing the status line
HttpResponse response = httpclient.execute(targetHost, httpget);
System.out.println(response.getStatusLine());
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод:
HTTP/1.1 200 OK
Используя библиотеку HttpClient, вы можете отправить запрос или войти в форму, передав параметры.
Следуйте инструкциям ниже, чтобы войти в форму.
Шаг 1. Создайте объект HttpClient
В createDefault() метод HttpClients class возвращает объект класса CloseableHttpClient, который является базовой реализацией интерфейса HttpClient. Используя этот метод, создайте объект HttpClient -
CloseableHttpClient httpClient = HttpClients.createDefault();
Шаг 2 - Создайте объект RequestBuilder
Класс RequestBuilderиспользуется для построения запроса путем добавления к нему параметров. Если тип запроса - PUT или POST, он добавляет параметры в запрос как объект с кодировкой URL.
Создайте объект RequestBuilder (типа POST) с помощью метода post ().
//Building the post request object
RequestBuilder reqbuilder = RequestBuilder.post();
Шаг 3 - Установите Uri и параметры в RequestBuilder.
Задайте URI и параметры для объекта RequestBuilder, используя setUri() и addParameter() методы класса RequestBuilder.
//Set URI and parameters
RequestBuilder reqbuilder = reqbuilder.setUri("http://httpbin.org/post");
reqbuilder = reqbuilder1.addParameter("Name", "username").addParameter("password", "password");
Шаг 4 - Создайте объект HttpUriRequest
После установки необходимых параметров построить HttpUriRequest объект с помощью build() метод.
//Building the HttpUriRequest object
HttpUriRequest httppost = reqbuilder2.build();
Шаг 5 - Выполните запрос
Метод execute объекта CloseableHttpClient принимает объект HttpUriRequest (интерфейс) (например, HttpGet, HttpPost, HttpPut, HttpHead и т. Д.) И возвращает объект ответа.
Выполните HttpUriRequest, созданный на предыдущих шагах, передав его в execute() метод.
//Execute the request
HttpResponse httpresponse = httpclient.execute(httppost);
пример
В следующем примере показано, как войти в форму, отправив учетные данные. Здесь мы отправили два параметра -username and password в форму и попытался распечатать сущность сообщения и статус запроса.
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.client.methods.RequestBuilder;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import java.io.IOException;
import java.net.URISyntaxException;
public class FormLoginExample {
public static void main(String args[]) throws Exception {
//Creating CloseableHttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
//Creating the RequestBuilder object
RequestBuilder reqbuilder = RequestBuilder.post();
//Setting URI and parameters
RequestBuilder reqbuilder1 = reqbuilder.setUri("http://httpbin.org/post");
RequestBuilder reqbuilder2 = reqbuilder1.addParameter("Name",
"username").addParameter("password", "password");
//Building the HttpUriRequest object
HttpUriRequest httppost = reqbuilder2.build();
//Executing the request
HttpResponse httpresponse = httpclient.execute(httppost);
//Printing the status and the contents of the response
System.out.println(EntityUtils.toString(httpresponse.getEntity()));
System.out.println(httpresponse.getStatusLine());
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод:
{
"args": {},
"data": "",
"files": {},
"form": {
"Name": "username",
"password": "password"
},
"headers": {
"Accept-Encoding": "gzip,deflate",
"Connection": "close",
"Content-Length": "31",
"Content-Type": "application/x-www-form-urlencoded; charset = UTF-8",
"Host": "httpbin.org",
"User-Agent": "Apache-HttpClient/4.5.6 (Java/1.8.0_91)"
},
"json": null,
"origin": "117.216.245.180",
"url": "http://httpbin.org/post"
}
HTTP/1.1 200 OK
Форма входа с помощью файлов cookie
Если ваша форма хранит файлы cookie, вместо создания по умолчанию CloseableHttpClient объект.
Create a CookieStore object путем создания экземпляра класса BasicCookieStore.
//Creating a BasicCookieStore object
BasicCookieStore cookieStore = new BasicCookieStore();
Create a HttpClientBuilder используя custom() метод HttpClients класс.
//Creating an HttpClientBuilder object
HttpClientBuilder clientbuilder = HttpClients.custom();
Set the cookie store to the client builder с помощью метода setDefaultCookieStore ().
//Setting default cookie store to the client builder object
Clientbuilder = clientbuilder.setDefaultCookieStore(cookieStore);
Построить CloseableHttpClient объект с помощью build() метод.
//Building the CloseableHttpClient object
CloseableHttpClient httpclient = clientbuilder1.build();
Построить HttpUriRequest объект, как указано выше, путем передачи выполнения запроса.
Если на странице хранятся файлы cookie, переданные вами параметры будут добавлены в хранилище файлов cookie.
Вы можете распечатать содержимое CookieStore объект, в котором вы можете увидеть свои параметры (наряду с предыдущими, страница хранится в кейсе).
Чтобы распечатать файлы cookie, получите все файлы cookie из CookieStore объект с помощью getCookies()метод. Этот метод возвращаетListобъект. Используя Iterator, распечатайте содержимое объектов списка, как показано ниже -
//Printing the cookies
List list = cookieStore.getCookies();
System.out.println("list of cookies");
Iterator it = list.iterator();
if(it.hasNext()) {
System.out.println(it.next());
}
Файлы cookie - это текстовые файлы, которые хранятся на клиентском компьютере, и они хранятся для различных целей отслеживания информации.
HttpClient обеспечивает поддержку файлов cookie, которые вы можете создавать и управлять ими.
Создание куки
Следуйте инструкциям ниже, чтобы создать файл cookie с использованием библиотеки HttpClient.
Шаг 1. Создайте объект Cookiestore
В CookieStoreИнтерфейс представляет собой абстрактное хранилище для объектов Cookie. Вы можете создать хранилище файлов cookie, создав экземплярBasicCookieStore class, реализация этого интерфейса по умолчанию.
//Creating the CookieStore object
CookieStore cookieStore = new BasicCookieStore();
Шаг 2 - Создайте объект ClientCookie
В дополнение к функциям cookie ClientCookie может получать исходные файлы cookie на сервере. Вы можете создать клиентский файл cookie, создав экземплярBasicClientCookieкласс. Конструктору этого класса вам необходимо передать пару ключ-значение, которую вы хотите сохранить в этом конкретном файле cookie.
//Creating client cookie
BasicClientCookie clientCookie = new BasicClientCookie("name","Raju");
Шаг 3 - Установите значения для файла cookie
Для клиентского cookie вы можете установить / удалить путь, значение, версию, дату истечения срока действия, домен, комментарий и атрибут, используя соответствующие методы.
Calendar myCal = new GregorianCalendar(2018, 9, 26);
Date expiryDate = myCal.getTime();
clientcookie.setExpiryDate(expiryDate);
clientcookie.setPath("/");
clientcookie.setSecure(true);
clientcookie.setValue("25");
clientcookie.setVersion(5);
Шаг 4 - Добавьте файл cookie в хранилище файлов cookie
Вы можете добавить файлы cookie в хранилище файлов cookie, используя addCookie() метод BasicCookieStore класс.
Добавьте необходимые файлы cookie в Cookiestore.
//Adding the created cookies to cookie store
cookiestore.addCookie(clientcookie);
пример
В следующем примере показано, как создавать файлы cookie и добавлять их в хранилище файлов cookie. Здесь мы создали хранилище файлов cookie, группу файлов cookie, установив значения домена и пути, и добавили их в хранилище файлов cookie.
import org.apache.http.client.CookieStore;
import org.apache.http.impl.client.BasicCookieStore;
import org.apache.http.impl.cookie.BasicClientCookie;
public class CookieHandlingExample {
public static void main(String args[]) throws Exception{
//Creating the CookieStore object
CookieStore cookiestore = new BasicCookieStore();
//Creating client cookies
BasicClientCookie clientcookie1 = new BasicClientCookie("name","Raju");
BasicClientCookie clientcookie2 = new BasicClientCookie("age","28");
BasicClientCookie clientcookie3 = new BasicClientCookie("place","Hyderabad");
//Setting domains and paths to the created cookies
clientcookie1.setDomain(".sample.com");
clientcookie2.setDomain(".sample.com");
clientcookie3.setDomain(".sample.com");
clientcookie1.setPath("/");
clientcookie2.setPath("/");
clientcookie3.setPath("/");
//Adding the created cookies to cookie store
cookiestore.addCookie(clientcookie1);
cookiestore.addCookie(clientcookie2);
cookiestore.addCookie(clientcookie3);
}
}
Получение куки
Вы можете добавить файлы cookie в хранилище файлов cookie, используя getCookies() метод asicCookieStoreкласс. Этот метод возвращает список, содержащий все файлы cookie в хранилище файлов cookie.
Вы можете распечатать содержимое хранилища файлов cookie с помощью Iterator, как показано ниже -
//Retrieving the cookies
List list = cookieStore.getCookies();
//Creating an iterator to the obtained list
Iterator it = list.iterator();
while(it.hasNext()) {
System.out.println(it.next());
}
пример
В следующем примере показано, как получить файлы cookie из хранилища файлов cookie. Здесь мы добавляем несколько файлов cookie в хранилище файлов cookie и получаем их обратно.
import org.apache.http.client.CookieStore;
import org.apache.http.impl.client.BasicCookieStore;
import org.apache.http.impl.cookie.BasicClientCookie;
public class CookieHandlingExample {
public static void main(String args[]) throws Exception{
//Creating the CookieStore object
CookieStore cookiestore = new BasicCookieStore();
//Creating client cookies
BasicClientCookie clientcookie1 = new BasicClientCookie("name","Raju");
BasicClientCookie clientcookie2 = new BasicClientCookie("age","28");
BasicClientCookie clientcookie3 = new BasicClientCookie("place","Hyderabad");
//Setting domains and paths to the created cookies
clientcookie1.setDomain(".sample.com");
clientcookie2.setDomain(".sample.com");
clientcookie3.setDomain(".sample.com");
clientcookie1.setPath("/");
clientcookie2.setPath("/");
clientcookie3.setPath("/");
//Adding the created cookies to cookie store
cookiestore.addCookie(clientcookie1);
cookiestore.addCookie(clientcookie2);
cookiestore.addCookie(clientcookie3);
}
}
Вывод
При выполнении эта программа генерирует следующий вывод -
[version: 0][name: age][value: 28][domain: .sample.com][path: /][expiry: null]
[version: 0][name: name][value: Raju][domain: my.example.com][path: /][expiry:
null]
[version: 0][name: place][value: Hyderabad][domain: .sample.com][path:
/][expiry: null]
Многопоточная программа состоит из двух или более частей, которые могут выполняться одновременно, и каждая часть может обрабатывать разные задачи одновременно, оптимально используя доступные ресурсы.
Вы можете выполнять запросы из нескольких потоков, написав многопоточную программу HttpClient.
Если вы хотите последовательно выполнять несколько клиентских запросов из потоков, вам необходимо создать ClientConnectionPoolManager. Он поддерживает пулHttpClientConnections и обслуживает несколько запросов от потоков.
Диспетчер соединений объединяет соединения на основе маршрута. Если у менеджера есть соединения для определенного маршрута, он обслуживает новые запросы по этим маршрутам, арендуя существующее соединение из пула, вместо того, чтобы создавать новое.
Следуйте инструкциям для выполнения запросов из нескольких потоков -
Шаг 1 - Создание диспетчера пула клиентских подключений
Создайте диспетчер пула клиентских подключений, создав экземпляр PoolingHttpClientConnectionManager класс.
PoolingHttpClientConnectionManager connManager = new
PoolingHttpClientConnectionManager();
Шаг 2 - Установите максимальное количество подключений
Установите максимальное количество подключений в пуле с помощью setMaxTotal() метод.
//Set the maximum number of connections in the pool
connManager.setMaxTotal(100);
Шаг 3 - Создайте объект ClientBuilder
Создать ClientBuilder Object, установив диспетчер соединений с помощью setConnectionManager() метод, как показано ниже -
HttpClientBuilder clientbuilder =
HttpClients.custom().setConnectionManager(connManager);
Шаг 4. Создайте объекты запроса HttpGet
Создайте экземпляр класса HttpGet, передав желаемый URI в его конструктор в качестве параметра.
HttpGet httpget1 = new HttpGet("URI1");
HttpGet httpget2 = new HttpGet("URI2");
. . . . . . . . . . . .
Шаг 5 - Реализация метода запуска
Убедитесь, что вы создали класс, сделали его потоком (либо путем расширения класса потока, либо путем реализации интерфейса Runnable) и реализовали метод run.
public class ClientMultiThreaded extends Thread {
public void run() {
//Run method implementation . . . . . . . . . .
}
}
Шаг 6 - Создание объектов Thread
Создайте объекты потока, создав экземпляр класса Thread (ClientMultiThreaded), созданного выше.
Передайте объект HttpClient, соответствующий объект HttpGet и целое число, представляющее идентификатор, этим потокам.
ClientMultiThreaded thread1 = new ClientMultiThreaded(httpclient,httpget1, 1);
ClientMultiThreaded thread2 = new ClientMultiThreaded(httpclient,httpget2, 2);
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . .
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
Шаг 7 - Начните и присоединяйтесь к обсуждениям
Запустите все потоки, используя start() метод и присоединиться к ним с помощью соединения method().
thread1.start();
thread2.start();
. . . . . . . .
thread1.join();
thread2.join();
. . . . . . . . . . . .
Шаг 8 - Выполните реализацию метода
В методе выполнения выполните запрос, получите ответ и распечатайте результаты.
пример
Следующий пример демонстрирует выполнение HTTP-запросов одновременно из нескольких потоков. В этом примере мы пытаемся выполнить различные запросы из разных потоков и пытаемся распечатать статус и количество байтов, прочитанных каждым клиентом.
import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.impl.conn.PoolingHttpClientConnectionManager;
import org.apache.http.util.EntityUtils;
public class ClientMultiThreaded extends Thread {
CloseableHttpClient httpClient;
HttpGet httpget;
int id;
public ClientMultiThreaded(CloseableHttpClient httpClient, HttpGet httpget,
int id) {
this.httpClient = httpClient;
this.httpget = httpget;
this.id = id;
}
@Override
public void run() {
try{
//Executing the request
CloseableHttpResponse httpresponse = httpClient.execute(httpget);
//Displaying the status of the request.
System.out.println("status of thread "+id+":"+httpresponse.getStatusLine());
//Retrieving the HttpEntity and displaying the no.of bytes read
HttpEntity entity = httpresponse.getEntity();
if (entity != null) {
System.out.println("Bytes read by thread thread "+id+":
"+EntityUtils.toByteArray(entity).length);
}
}catch(Exception e) {
System.out.println(e.getMessage());
}
}
public static void main(String[] args) throws Exception {
//Creating the Client Connection Pool Manager by instantiating the PoolingHttpClientConnectionManager class.
PoolingHttpClientConnectionManager connManager = new PoolingHttpClientConnectionManager();
//Set the maximum number of connections in the pool
connManager.setMaxTotal(100);
//Create a ClientBuilder Object by setting the connection manager
HttpClientBuilder clientbuilder = HttpClients.custom().setConnectionManager(connManager);
//Build the CloseableHttpClient object using the build() method.
CloseableHttpClient httpclient = clientbuilder.build();
//Creating the HttpGet requests
HttpGet httpget1 = new HttpGet("http://www.tutorialspoint.com/");
HttpGet httpget2 = new HttpGet("http://www.google.com/");
HttpGet httpget3 = new HttpGet("https://www.qries.com/");
HttpGet httpget4 = new HttpGet("https://in.yahoo.com/");
//Creating the Thread objects
ClientMultiThreaded thread1 = new ClientMultiThreaded(httpclient,httpget1, 1);
ClientMultiThreaded thread2 = new ClientMultiThreaded(httpclient,httpget2, 2);
ClientMultiThreaded thread3 = new ClientMultiThreaded(httpclient,httpget3, 3);
ClientMultiThreaded thread4 = new ClientMultiThreaded(httpclient,httpget4, 4);
//Starting all the threads
thread1.start();
thread2.start();
thread3.start();
thread4.start();
//Joining all the threads
thread1.join();
thread2.join();
thread3.join();
thread4.join();
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод:
status of thread 1: HTTP/1.1 200 OK
Bytes read by thread thread 1: 36907
status of thread 2: HTTP/1.1 200 OK
Bytes read by thread thread 2: 13725
status of thread 3: HTTP/1.1 200 OK
Bytes read by thread thread 3: 17319
status of thread 4: HTTP/1.1 200 OK
Bytes read by thread thread 4: 127018
Используя Secure Socket Layer, вы можете установить защищенное соединение между клиентом и сервером. Это помогает защитить конфиденциальную информацию, такую как номера кредитных карт, имена пользователей, пароли, булавки и т. Д.
Вы можете сделать соединения более безопасными, создав свой собственный SSL-контекст с помощью HttpClient библиотека.
Следуйте инструкциям ниже, чтобы настроить SSLContext с помощью библиотеки HttpClient -
Шаг 1 - Создайте объект SSLContextBuilder
SSLContextBuilderявляется строителем для объектов SSLContext. Создайте его объект, используяcustom() метод SSLContexts класс.
//Creating SSLContextBuilder object
SSLContextBuilder SSLBuilder = SSLContexts.custom();
Шаг 2 - Загрузите хранилище ключей
В пути Java_home_directory/jre/lib/security/, вы можете найти файл cacerts. Сохраните его как файл хранилища ключей (с расширением .jks). Загрузите файл хранилища ключей и его пароль (которыйchangeit по умолчанию) с помощью loadTrustMaterial() метод SSLContextBuilder класс.
//Loading the Keystore file
File file = new File("mykeystore.jks");
SSLBuilder = SSLBuilder.loadTrustMaterial(file, "changeit".toCharArray());
Шаг 3 - создайте объект SSLContext
Объект SSLContext представляет реализацию протокола безопасного сокета. Создайте SSLContext с помощьюbuild() метод.
//Building the SSLContext
SSLContext sslContext = SSLBuilder.build();
Шаг 4 - Создание объекта SSLConnectionSocketFactory
SSLConnectionSocketFactoryпредставляет собой многоуровневую фабрику сокетов для соединений TSL и SSL. Используя это, вы можете проверить Https-сервер с помощью списка доверенных сертификатов и аутентифицировать данный Https-сервер.
Вы можете создать это разными способами. В зависимости от того, как вы создаетеSSLConnectionSocketFactory объект, вы можете разрешить все хосты, разрешить только самозаверяющие сертификаты, разрешить только определенные протоколы и т. д.
To allow only particular protocols, Создайте SSLConnectionSocketFactory объект, передав объект SSLContext, массив строк, представляющий протоколы, которые должны поддерживаться, массив строк, представляющий костюмы шифров, которые должны поддерживаться, и объект HostnameVerifier в его конструктор.
new SSLConnectionSocketFactory(sslcontext, new String[]{"TLSv1"}, null,
SSLConnectionSocketFactory.getDefaultHostnameVerifier());
To allow all hosts, Создайте SSLConnectionSocketFactory объект, передав объект SSLContext и NoopHostnameVerifier объект.
//Creating SSLConnectionSocketFactory SSLConnectionSocketFactory object
SSLConnectionSocketFactory sslConSocFactory = new SSLConnectionSocketFactory(sslcontext, new NoopHostnameVerifier());
Шаг 5 - Создайте объект HttpClientBuilder
Создайте объект HttpClientBuilder, используя custom() метод HttpClients класс.
//Creating HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();
Шаг 6 - Установите объект SSLConnectionSocketFactory
Задайте для объекта SSLConnectionSocketFactory значение HttpClientBuilder используя setSSLSocketFactory() метод.
//Setting the SSLConnectionSocketFactory
clientbuilder = clientbuilder.setSSLSocketFactory(sslConSocFactory);
Шаг 7 - Создайте объект CloseableHttpClient
Построить CloseableHttpClient объект, вызвав build() метод.
//Building the CloseableHttpClient
CloseableHttpClient httpclient = clientbuilder.build();
Шаг 8 - Создайте объект HttpGet
В HttpGet Класс представляет HTTP-запрос GET, который извлекает информацию о данном сервере с использованием URI.
Создайте запрос HTTP GET, создав экземпляр класса HttpGet, передав строку, представляющую URI.
//Creating the HttpGet request
HttpGet httpget = new HttpGet("https://example.com/");
Шаг 9 - Выполните запрос
Выполните запрос, используя execute() метод.
//Executing the request
HttpResponse httpresponse = httpclient.execute(httpget);
пример
В следующем примере демонстрируется настройка SSLContrext -
import java.io.File;
import javax.net.ssl.SSLContext;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.conn.ssl.NoopHostnameVerifier;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.ssl.SSLContextBuilder;
import org.apache.http.ssl.SSLContexts;
import org.apache.http.util.EntityUtils;
public class ClientCustomSSL {
public final static void main(String[] args) throws Exception {
//Creating SSLContextBuilder object
SSLContextBuilder SSLBuilder = SSLContexts.custom();
//Loading the Keystore file
File file = new File("mykeystore.jks");
SSLBuilder = SSLBuilder.loadTrustMaterial(file,
"changeit".toCharArray());
//Building the SSLContext usiong the build() method
SSLContext sslcontext = SSLBuilder.build();
//Creating SSLConnectionSocketFactory object
SSLConnectionSocketFactory sslConSocFactory = new SSLConnectionSocketFactory(sslcontext, new NoopHostnameVerifier());
//Creating HttpClientBuilder
HttpClientBuilder clientbuilder = HttpClients.custom();
//Setting the SSLConnectionSocketFactory
clientbuilder = clientbuilder.setSSLSocketFactory(sslConSocFactory);
//Building the CloseableHttpClient
CloseableHttpClient httpclient = clientbuilder.build();
//Creating the HttpGet request
HttpGet httpget = new HttpGet("https://example.com/");
//Executing the request
HttpResponse httpresponse = httpclient.execute(httpget);
//printing the status line
System.out.println(httpresponse.getStatusLine());
//Retrieving the HttpEntity and displaying the no.of bytes read
HttpEntity entity = httpresponse.getEntity();
if (entity != null) {
System.out.println(EntityUtils.toByteArray(entity).length);
}
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод.
HTTP/1.1 200 OK
1270
Используя HttpClient, мы можем выполнять многостраничную загрузку, то есть мы можем загружать более крупные объекты меньшими частями. В этой главе мы продемонстрируем многостраничную загрузку в HTTP-клиенте, загрузив простой текстовый файл.
Как правило, любая составная загрузка состоит из трех частей.
Начало загрузки
Загрузка частей объекта
Завершение составной загрузки
Для многокомпонентной загрузки с использованием HttpClient нам необходимо выполнить следующие шаги:
Создайте составной строитель.
Добавьте к нему желаемые детали.
Завершите сборку и получите составной HttpEntity.
Создайте запрос, установив указанную выше сущность muti-part.
Выполните запрос.
Ниже приведены шаги по загрузке составной сущности с использованием библиотеки HttpClient.
Шаг 1. Создайте объект HttpClient
В createDefault() метод HttpClients class возвращает объект класса CloseableHttpClient, который является базовой реализацией интерфейса HttpClient. Используя этот метод, создайте объект HttpClient -
//Creating CloseableHttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
Шаг 2 - Создайте объект FileBody
FileBodyКласс представляет двоичную часть тела, поддерживаемую файлом. Создайте экземпляр этого класса, передавFile объект и ContentType объект, представляющий тип содержимого.
//Creating a File object
File file = new File("sample.txt");
//Creating the FileBody object
FileBody filebody = new FileBody(file, ContentType.DEFAULT_BINARY);
Шаг 3 - Создайте MultipartEntityBuilder
В MultipartEntityBuilder класс используется для создания составной части HttpEntityобъект. Создайте его объект, используяcreate() метод (того же класса).
//Creating the MultipartEntityBuilder
MultipartEntityBuilder entitybuilder = MultipartEntityBuilder.create();
Шаг 4 - Установите режим
А MultipartEntityBuilderимеет три режима: STRICT, RFC6532 и BROWSER_COMPATIBLE. Установите желаемый режим с помощьюsetMode() метод.
//Setting the mode
entitybuilder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
Шаг 5 - Добавьте различные желаемые детали
Используя методы addTextBody(), addPart () и, addBinaryBody(), вы можете добавить простой текст, файлы, потоки и другие объекты в MultipartBuilder. Добавьте желаемое содержимое, используя эти методы.
//Adding text
entitybuilder.addTextBody("sample_text", "This is the text part of our file");
//Adding a file
entitybuilder.addBinaryBody("image", new File("logo.png"));
Шаг 6 - Создание единого объекта
Вы можете собрать все эти части в единое целое, используя build() метод MultipartEntityBuilderкласс. Используя этот метод, соберите все части в единыйHttpEntity.
//Building a single entity using the parts
HttpEntity mutiPartHttpEntity = entityBuilder.build();
Шаг 7 - Создайте объект RequestBuilder
Класс RequestBuilderиспользуется для построения запроса путем добавления к нему параметров. Если запрос относится к типу PUT или POST, он добавляет параметры к запросу как объект с кодировкой URL.
Создайте объект RequestBuilder (типа POST), используя post()метод. И передайте Uri, на который вы хотите отправить запрос, в качестве параметра.
//Building the post request object
RequestBuilder reqbuilder = RequestBuilder.post("http://httpbin.org/post");
Шаг 8 - Установите объект сущности в RequestBuilder
Установите созданный выше составной объект в RequestBuilder, используя setEntity() метод RequestBuilder класс.
//Setting the entity object to the RequestBuilder
reqbuilder.setEntity(mutiPartHttpEntity);
Шаг 9 - Создайте HttpUriRequest
Построить HttpUriRequest объект запроса с помощью build() метод RequestBuilder класс.
//Building the request
HttpUriRequest multipartRequest = reqbuilder.build();
Шаг 10 - Выполните запрос
Используя execute() , выполните запрос, построенный на предыдущем шаге (минуя запрос как параметр этого метода).
//Executing the request
HttpResponse httpresponse = httpclient.execute(multipartRequest);
пример
В следующем примере показано, как отправить составной запрос с помощью библиотеки HttpClient. В этом примере мы пытаемся отправить составной запрос, поддерживаемый файлом.
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpUriRequest;
import org.apache.http.client.methods.RequestBuilder;
import org.apache.http.entity.ContentType;
import org.apache.http.entity.mime.HttpMultipartMode;
import org.apache.http.entity.mime.MultipartEntityBuilder;
import org.apache.http.entity.mime.content.FileBody;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import java.io.File;
import java.io.IOException;
import java.net.URISyntaxException;
public class MultipartUploadExample {
public static void main(String args[]) throws Exception{
//Creating CloseableHttpClient object
CloseableHttpClient httpclient = HttpClients.createDefault();
//Creating a file object
File file = new File("sample.txt");
//Creating the FileBody object
FileBody filebody = new FileBody(file, ContentType.DEFAULT_BINARY);
//Creating the MultipartEntityBuilder
MultipartEntityBuilder entitybuilder = MultipartEntityBuilder.create();
//Setting the mode
entitybuilder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE);
//Adding text
entitybuilder.addTextBody("sample_text", "This is the text part of our file");
//Adding a file
entitybuilder.addBinaryBody("image", new File("logo.png"));
//Building a single entity using the parts
HttpEntity mutiPartHttpEntity = entitybuilder.build();
//Building the RequestBuilder request object
RequestBuilder reqbuilder = RequestBuilder.post("http://httpbin.org/post");
//Set the entity object to the RequestBuilder
reqbuilder.setEntity(mutiPartHttpEntity);
//Building the request
HttpUriRequest multipartRequest = reqbuilder.build();
//Executing the request
HttpResponse httpresponse = httpclient.execute(multipartRequest);
//Printing the status and the contents of the response
System.out.println(EntityUtils.toString(httpresponse.getEntity()));
System.out.println(httpresponse.getStatusLine());
}
}
Вывод
При выполнении вышеуказанная программа генерирует следующий вывод:
{
"args": {},
"data": "",
"files": {
"image": "data:application/octets66PohrH3IWNk1FzpohfdXPIfv9X3490FGcuXsHn9X0piCwomF/xdgADZ9GsfSyvLYAAAAAE
lFTkSuQmCC"
},
"form": {
"sample_text": "This is the text part of our file"
},
"headers": {
"Accept-Encoding": "gzip,deflate",
"Connection": "close",
"Content-Length": "11104",
"Content-Type": "multipart/form-data;
boundary=UFJbPHT7mTwpVq70LpZgCi5I2nvxd1g-I8Rt",
"Host": "httpbin.org",
"User-Agent": "Apache-HttpClient/4.5.6 (Java/1.8.0_91)"
},
"json": null,
"origin": "117.216.245.180",
"url": "http://httpbin.org/post"
}
HTTP/1.1 200 OK