Рубрики
Без рубрики

Руководство по беспорядкам

Откройте для себя Unrest – облегченную клиентскую библиотеку HTTP.

Автор оригинала: baeldung.

1. Обзор

Unirest – это облегченная клиентская библиотека HTTP от Mashape. Наряду с Java, он также доступен для Node.js, .Net, Python, Ruby и т. Д.

Прежде чем мы начнем, обратите внимание, что мы будем использовать mocky.io для всех наших HTTP-запросов здесь.

2. Настройка Maven

Для начала давайте сначала добавим необходимые зависимости:


    com.mashape.unirest
    unirest-java
    1.4.9

Ознакомьтесь с последней версией здесь .

3. Простые запросы

Давайте отправим простой HTTP-запрос, чтобы понять семантику фреймворка:

@Test
public void shouldReturnStatusOkay() {
    HttpResponse jsonResponse 
      = Unirest.get("http://www.mocky.io/v2/5a9ce37b3100004f00ab5154")
      .header("accept", "application/json").queryString("apiKey", "123")
      .asJson();

    assertNotNull(jsonResponse.getBody());
    assertEquals(200, jsonResponse.getStatus());
}

Обратите внимание, что API свободно, эффективно и довольно легко читается.

Мы передаем заголовки и параметры с помощью API header() и fields () .

И запрос вызывается при вызове метода asJson () ; у нас также есть другие варианты здесь, такие как as Binary(), as String() и asObject().

Чтобы передать несколько заголовков или полей, мы можем создать карту и передать их в .headers(Map Object> headers) и .fields(Map String> fields) соответственно: Object> headers)

@Test
public void shouldReturnStatusAccepted() {
    Map headers = new HashMap<>();
    headers.put("accept", "application/json");
    headers.put("Authorization", "Bearer 5a9ce37b3100004f00ab5154");

    Map fields = new HashMap<>();
    fields.put("name", "Sam Baeldung");
    fields.put("id", "PSP123");

    HttpResponse jsonResponse 
      = Unirest.put("http://www.mocky.io/v2/5a9ce7853100002a00ab515e")
      .headers(headers).fields(fields)
      .asJson();
 
    assertNotNull(jsonResponse.getBody());
    assertEquals(202, jsonResponse.getStatus());
}

3.1. Передача Параметров Запроса

Чтобы передать данные в виде запроса String, мы будем использовать метод queryString() :

HttpResponse jsonResponse 
  = Unirest.get("http://www.mocky.io/v2/5a9ce37b3100004f00ab5154")
  .queryString("apiKey", "123")

3.2. Использование Параметров Пути

Для передачи любых параметров URL-адреса мы можем использовать метод route Param() :

HttpResponse jsonResponse 
  = Unirest.get("http://www.mocky.io/v2/5a9ce37b3100004f00ab5154/{userId}")
  .routeParam("userId", "123")

Имя заполнителя параметра должно совпадать с первым аргументом метода.

3.3. Запросы С Телом

Если для нашего запроса требуется тело строки/JSON, мы передаем его с помощью метода body() :

@Test
public void givenRequestBodyWhenCreatedThenCorrect() {

    HttpResponse jsonResponse 
      = Unirest.post("http://www.mocky.io/v2/5a9ce7663100006800ab515d")
      .body("{\"name\":\"Sam Baeldung\", \"city\":\"viena\"}")
      .asJson();
 
    assertEquals(201, jsonResponse.getStatus());
}

3.4. Картограф объектов

Чтобы использовать их в качестве объекта() или тела() в запросе, нам нужно определить наш картограф объектов. Для простоты мы будем использовать картограф объектов Джексона.

Давайте сначала добавим следующие зависимости в pom.xml :


    com.fasterxml.jackson.core
    jackson-databind
    2.9.4

Всегда используйте последнюю версию поверх на Maven Central .

Теперь давайте настроим наш картограф:

Unirest.setObjectMapper(new ObjectMapper() {
    com.fasterxml.jackson.databind.ObjectMapper mapper 
      = new com.fasterxml.jackson.databind.ObjectMapper();

    public String writeValue(Object value) {
        return mapper.writeValueAsString(value);
    }

    public  T readValue(String value, Class valueType) {
        return mapper.readValue(value, valueType);
    }
});

Обратите внимание, что setObjectMapper() должен вызываться только один раз для настройки картографа; как только экземпляр картографа будет установлен, он будет использоваться для всех запросов и ответов.

Теперь давайте протестируем новую функциональность с помощью пользовательского объекта Article :

@Test
public void givenArticleWhenCreatedThenCorrect() {
    Article article 
      = new Article("ID1213", "Guide to Rest", "baeldung");
    HttpResponse jsonResponse 
      = Unirest.post("http://www.mocky.io/v2/5a9ce7663100006800ab515d")
      .body(article)
      .asJson();
 
    assertEquals(201, jsonResponse.getStatus());
}

4. Методы запроса

Как и любой HTTP-клиент, платформа предоставляет отдельные методы для каждого HTTP-глагола:

ПОСТ:

Unirest.post("http://www.mocky.io/v2/5a9ce7663100006800ab515d")

КЛАСТЬ:

Unirest.put("http://www.mocky.io/v2/5a9ce7663100006800ab515d")

ПОЛУЧИТЬ:

Unirest.get("http://www.mocky.io/v2/5a9ce7663100006800ab515d")

УДАЛИТЬ:

Unirest.delete("http://www.mocky.io/v2/5a9ce7663100006800ab515d")

ЗАПЛАТКА:

Unirest.patch("http://www.mocky.io/v2/5a9ce7663100006800ab515d")

ОПЦИИ:

Unirest.options("http://www.mocky.io/v2/5a9ce7663100006800ab515d")

5. Методы реагирования

Как только мы получим ответ, давайте проверим код состояния и сообщение о состоянии:

//...
jsonResponse.getStatus()

//...

Извлеките заголовки:

//...
jsonResponse.getHeaders();
//...

Получить тело ответа:

//...
jsonResponse.getBody();
jsonResponse.getRawBody();
//...

Обратите внимание, что getRawBody(), возвращает поток нерассмотренного тела ответа, в то время как getBody() возвращает проанализированное тело, используя сопоставитель объектов, определенный в предыдущем разделе.

6. Обработка Асинхронных Запросов

Unirest также имеет возможность обрабатывать асинхронные запросы с помощью java.util.concurrent.Будущее и методы обратного вызова:

@Test
public void whenAysncRequestShouldReturnOk() {
    Future> future = Unirest.post(
      "http://www.mocky.io/v2/5a9ce37b3100004f00ab5154?mocky-delay=10000ms")
      .header("accept", "application/json")
      .asJsonAsync(new Callback() {

        public void failed(UnirestException e) {
            // Do something if the request failed
        }

        public void completed(HttpResponse response) {
            // Do something if the request is successful
        }

        public void cancelled() {
            // Do something if the request is cancelled
        }
        });
 
    assertEquals(200, future.get().getStatus());
}

com.mashape.unirest.http.async.Обратный вызов интерфейс предоставляет три метода: failed() , cancelled() и completed().

Переопределите методы для выполнения необходимых операций в зависимости от ответа.

7. Загрузка файлов

Чтобы загрузить или отправить файл как часть запроса, передайте java.io.Файл объект в виде поля с именем file:

@Test
public void givenFileWhenUploadedThenCorrect() {

    HttpResponse jsonResponse = Unirest.post(
      "http://www.mocky.io/v2/5a9ce7663100006800ab515d")
      .field("file", new File("/path/to/file"))
      .asJson();
 
    assertEquals(201, jsonResponse.getStatus());
}

Мы также можем использовать Байтовый поток:

@Test
public void givenByteStreamWhenUploadedThenCorrect() {
    try (InputStream inputStream = new FileInputStream(
      new File("/path/to/file/artcile.txt"))) {
        byte[] bytes = new byte[inputStream.available()];
        inputStream.read(bytes);
        HttpResponse jsonResponse = Unirest.post(
          "http://www.mocky.io/v2/5a9ce7663100006800ab515d")
          .field("file", bytes, "article.txt")
          .asJson();
 
        assertEquals(201, jsonResponse.getStatus());
    }
}

Или используйте входной поток напрямую, добавив тип содержимого .APPLICATION_OCTET_STREAM в качестве второго аргумента в методе fields() :

@Test
public void givenInputStreamWhenUploadedThenCorrect() {
    try (InputStream inputStream = new FileInputStream(
      new File("/path/to/file/artcile.txt"))) {

        HttpResponse jsonResponse = Unirest.post(
          "http://www.mocky.io/v2/5a9ce7663100006800ab515d")
          .field("file", inputStream, ContentType.APPLICATION_OCTET_STREAM, "article.txt").asJson();
 
        assertEquals(201, jsonResponse.getStatus());
    }
}

8. Конфигурации Unirest

Фреймворк также поддерживает типичные конфигурации HTTP-клиента, такие как пул соединений, тайм-ауты, глобальные заголовки и т. Д.

Давайте установим количество соединений и максимальное количество соединений на маршрут:

Unirest.setConcurrency(20, 5);

Настройка таймаутов подключения и сокета:

Unirest.setTimeouts(20000, 15000);

Обратите внимание, что значения времени указаны в миллисекундах.

Теперь давайте установим заголовки HTTP для всех наших запросов:

Unirest.setDefaultHeader("X-app-name", "baeldung-unirest");
Unirest.setDefaultHeader("X-request-id", "100004f00ab5");

Мы можем очистить глобальные заголовки в любое время:

Unirest.clearDefaultHeaders();

В какой-то момент нам может потребоваться сделать запросы через прокси-сервер:

Unirest.setProxy(new HttpHost("localhost", 8080));

Одним из важных аспектов, о котором следует помнить, является изящное закрытие или выход из приложения. Это порождает цикл фоновых событий для обработки операций, нам нужно закрыть этот цикл перед выходом из нашего приложения:

Unirest.shutdown();

9. Заключение

В этом уроке мы сосредоточились на облегченной клиентской платформе HTTP – Unirest. Мы работали с несколькими простыми примерами, как в синхронном, так и в асинхронном режимах.

Наконец, мы также использовали несколько расширенных конфигураций, таких как пул соединений, настройки прокси-сервера и т. Д.

Как обычно, исходный код доступен на GitHub .