Перейти к основному содержимому

POST-запрос

🔗 Оригинальная страница — Источник данного материала


Описание

ZennoPoster позволяет отправлять данные в POST-запросах. С этим экшеном вы можете:

  • отсылать информацию для регистрации на сайте,
  • загружать файлы на сервер,
  • быстро отправлять данные,
  • запускать шаблоны без браузера,
  • работать с API веб-сервисов и приложений.

image-20200809-124636

Как добавить экшен в проект?

Через контекстное меню: Добавить действиеHTTPPOST-запрос

image-20200809-124810


Вкладка «Основные»

image-20210529-142810

URL

Целевой адрес сайта (ссылка), по которому будет отправлен запрос. Можно использовать переменную.

Referer

Заголовок запроса Referer используется для указания URL-адрес, с которого пользователь пришел на текущую страницу. Он помогает анализировать трафик и узнавать, с какого ресурса переходят чаще всего.

Заголовок Referer может раскрыть информацию об истории посещённых страниц

Это может привести к нарушению приватности.

Кодировка

Выбираем кодировку для запроса.

Таймаут

Максимальное время ожидания ответа от сайта в секундах.

При достижении установленного времени, действие будет завершено ошибкой и выйдет по красной ветке.

Можно использовать макросы переменных.


Данные

Основное содержимое запроса.

Тип данных

Определяем данные для текущего запроса.

Выбранный тип передаётся как заголовок Content-Type.

urlencoded

Content-Type: application/x-www-form-urlencoded

Стоит использовать, когда на сервер отсылается текстовая информация.

В поле Данные она указывается в формате: имяпараметра1=значение1&имяпараметра2=значение2

multipart

Content-Type: multipart/form-data

Этот тип стоит выбирать при отправке в запросе двоичных данных (файлов) на сервер.

Другой

Вы можете указать данный тип данных, если описанные выше не подходят.

Например, для взаимодействия с CapMonster Cloud API требуется отправлять данные POST запросом в формате JSON. Для этого выбираем Другой и в появившемся поле пишем: application/json

image-20210529-144909


Загружать

Только содержимое.

В переменную будет сохранено только тело ответа.

Только заголовки.

Сохранятся только заголовки.

Заголовки и содержимое.

В переменную сохранятся и заголовок ответа, и его тело, разделенные двумя пустыми строками.

Как файл.

Выбирайте этот режим, если нужно скачать файл с помощью запроса.
В переменную сохранится путь к скачанному файлу.

По умолчанию файлы скачиваются в папку Trash в директории с программой.

Путь может выглядеть так:
C:\Program Files\ZennoLab\RU\ZennoPoster Pro V7\7.4.0.0\Progs\Trash\googlelogo_color_92x30dp.png

Изменить его можно в настройках, но только глобально для всех проектов.

Как файл + заголовки.

В переменную сохранятся заголовки ответа и путь к скачанному файлу.


Положить в переменную.

Здесь надо выбрать (или создать новую) переменную, в которую будет сохранён результат запроса.


Вкладка «Дополнительно»

image-20210525-142622

Редирект.

Используется для установки перенаправления. Если ответ на запрос будет содержать код редиректа, то ZennoDroid перейдет к следующей странице, используя заголовок Location.

Здесь мы цифрами указываем максимальное количество переходов. К примеру, 0 — остаться на исходной странице, 5 — количество переходов до конечного URL.

Использовать оригинальный URL.

Когда эта опция включена, кодирование URL из вкладки «Основные» будет отменено. Пример:

  • URL по умолчанию (с кодированием):
    https://ru.wikipedia.org/wiki/%D0%9F%D1%80%D0%B8%D0%B2%D0%B5%D1%82%D1%81%D1%82%D0%B2%D0%B8%D0%B5
  • Оригинальный URL:
    https://ru.wikipedia.org/wiki/Приветствие

Заголовки.

Использовать по умолчанию.

В запрос будут подставлены заголовки по умолчанию. Заголовок Host меняется в зависимости от адреса в запросе.

Пример ответа при запросе https://httpbin.org/get.
Host: httpbin.org
User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:45.0) Gecko/20100101 Firefox/45.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.5

Текущий профиль.

Будут подставлены заголовки из текущего профиля проекта.

Загрузить из профиля.

Необходимо выбрать файл или указать переменную, содержащую путь до профиля, из которого будут загружены заголовки для запроса.

Пользовательские настройки.

image-20210529-091044

Позволяет самостоятельно указать каждый параметр заголовка, следуя правилам:

  • ⚠️ Первой всегда указывается строка User-Agent! И только потом все остальные заголовки.
  • Каждый заголовок начинается с новой строчки.
  • Можно указать статичные значения, свои переменные или переменные профиля.

Использовать CookieContainer.

С помощью этой опции можно синхронизировать куки с целым браузером или между отдельными запросами. Вам не понадобится вручную их парсить и подставлять.

Пример

Представим, что наш проект работает с сайтом, используя запросы. Для работы нужно быть авторизованным. При этом процесс авторизации крайне сложен для повторения его через запросы. Поэтому для входа на сайт используем браузерный режим.

После авторизации отключаем браузер и начинаем работать с запросами. С включенной опцией Использовать CookieContainer куки будут автоматически синхронизированы между браузером и запросами, их не придется подставлять вручную.

Если при одном из запросов сайт вернет новое значение кук, то оно автоматически синхронизируется с браузером и будет использовано в дальнейшем.

Данное поле ввода отображается только при отключении прошлой опции.

image-20210525-151513

Можно указать готовые куки или взять из переменной.

Формат: имя=значение, несколько значений разделяются через ;
Пример: user=1992103;session=f79fcadd847b80f9df78ba4fb276c867;id=889


Вкладка «Прокси»

image-20210529-084701

Без прокси

Экшен будет работать через реальный IP компьютера или сервера.

Текущий прокси проекта

Используется установленный в проекте прокси.

Строка формата

image-20210529-084950

Указываем прокси в формате (можно указать переменную):

  • С авторизациейsocks5://логин:пароль@ip:port или http://логин:пароль@ip:port
  • Без авторизацииsocks5://ip:port или http://ip:port
  • Без указания протокола (по умолчанию http://)логин:пароль@ip:port или ip:port

Другой

Выбираем в том случае, если нужно указать детальные настройки прокси.

image-20210529-085221

Тип прокси, данные авторизации, адрес и порт уточняйте у поставщика услуг.

Во всех полях можно использовать переменные.

ПО УМОЛЧАНИЮ ИСПОЛЬЗУЕТСЯ HTTP://

Если не указывать протокол прокси.


Создание экшенов из монитора трафика

Добавлено в ZennoPoster 7.1.5.0 (5.44.0.0)

Готовый HTTP-запрос можно создать прямо из Окна Трафика.

image-20200810-163348

  1. Наводим курсор на нужный запрос и правой кнопкой мыши вызываем контекстное меню.
  2. Нажимаем Создать действие из запроса.

На холсте проекта появится полностью заполненный экшен HTTP-запроса:

image-20200810-163642image-20200810-163654

Измените статические значение или замените на перемененные — теперь экшен полностью готов к работе.


Вспомогательные настройки

Выключение браузера

Если вы работаете исключительно на запросах, то можно отключить браузер, тем самым сэкономив ресурсы компьютера. Сделать это можно через Настройки проекта или в экшене Настройки браузера.

image-20200810-112931

Способ передачи запроса

В ZennoPoster есть два метода работы с запросами:

  • Стандартный. Стоит по умолчанию (библиотека Chilkat).
  • Альтернативный. Наша собственная разработка.

Если при работе с HTTP-запросами что-то работает неправильно, то попробуйте переключиться на альтернативный метод.
Сделать это можно через Настройки → Выполнение → Использовать альтернативный способ передачи HTTP-запросов.

image-20200808-214404


Пример использования

Допустим, нам нужно отправить ответ для ReCaptcha2 на сайт для прохождение антибот-системы.

image-20200812-202427

  1. Получаем ответ капчи
  2. Добавляем экшен POST-запрос
  3. Заполняем все поля
  4. В Данных указываем ответ капчи в нужном формате
  5. Отправляем ответ на сайте
  6. Проходим защиту сайта

Используя метод работы без браузера вы сэкономите время и ресурсы, затрачиваемые при разгадывании капчи в окне таба.


Полезные ссылки