2.5 KiB
curl
Передавать данные с сервера или на сервер. Поддерживает большинство протоколов, включая HTTP, HTTPS, FTP, SCP и другие. Смотрите также:
wcurl,wget. Больше информации: https://curl.se/docs/manpage.html.
- Выполнить HTTP GET-запрос и вывести содержимое в
stdout:
curl {{https://example.com}}
- Выполнить HTTP GET-запрос, следуя перенаправлениям
3xx, и вывести заголовки ответа и содержимое вstdout:
curl {{[-L|--location]}} {{[-D|--dump-header]}} - {{https://example.com}}
- Скачать файл, сохранив его под именем, указанным в URL:
curl {{[-O|--remote-name]}} {{https://example.com/filename.zip}}
- Отправить данные формы (POST-запрос типа
application/x-www-form-urlencoded). Используйте--data @file_nameили--data @'-'для чтения изstdin:
curl {{[-X|--request]}} POST {{[-d|--data]}} '{{name=bob}}' {{http://example.com/form}}
- Отправить запрос с дополнительным заголовком, используя пользовательский HTTP-метод через прокси (например, BurpSuite), игнорируя самоподписанные сертификаты:
curl {{[-k|--insecure]}} {{[-x|--proxy]}} {{http://127.0.0.1:8080}} {{[-H|--header]}} '{{Authorization: Bearer token}}' {{[-X|--request]}} {{GET|PUT|POST|DELETE|PATCH|...}} {{https://example.com}}
- Отправить данные в формате JSON, указав соответствующий заголовок Content-Type:
curl {{[-d|--data]}} '{{{"name":"bob"}}}' {{[-H|--header]}} '{{Content-Type: application/json}}' {{http://example.com/users/1234}}
- Передать клиентский сертификат и приватный ключ для запроса, пропуская проверку сертификата:
curl {{[-E|--cert]}} {{client.pem}} --key {{key.pem}} {{[-k|--insecure]}} {{https://example.com}}
- Привязать имя хоста к определённому IP-адресу с подробным выводом (аналог редактирования
/etc/hostsдля пользовательского разрешения DNS):
curl {{[-v|--verbose]}} --resolve {{example.com}}:{{80}}:{{127.0.0.1}} {{http://example.com}}