Как отправить POST с телом, заголовками и HTTP-параметрами, используя cURL?

39

Я нашел много примеров того, как использовать простые команды POST в cURL, но я не нашел примеров того, как отправлять полные команды HTTP POST, которые содержат:

  • Заголовки (базовая аутентификация)
  • HTTP-параметры ( s=1&r=33)
  • Данные тела, некоторая строка XML

Все, что я нашел, это:

echo "this is body" | curl -d "ss=ss&qq=11" http://localhost/

Это не работает, и он отправляет параметры HTTP как тело.

user71020
источник
Похоже на возможный обман superuser.com/questions/149329/… Я знаю, что этот вопрос касается заголовков и тому подобного, но ответы на другой вопрос также справляются с этим. Я обычно не отмечаю такой старый популярный вопрос как обман, но это исключение. Возможно, нужно переместить некоторые вещи для полноты.
Майкл Даррант
На самом деле другой ответ очень конкретно упоминает, --headerа этот - нет
Майкл Даррант

Ответы:

15

Не достаточно репутации, чтобы комментировать, поэтому оставьте это как ответ, надеясь, что это поможет.

curl -L -v --post301 --post302 -i -X PUT -T "${aclfile}"  \
  -H "Date: ${dateValue}" \
  -H "Content-Type: ${contentType}" \
  -H "Authorization: AWS ${s3Key}:${signature}" \
  ${host}:${port}${resource}

Это то, что я использовал для операции S3 Bucket S3. Заголовки находятся в -H, а тело, которое представляет собой XML-файл, находится в $ {aclfile} после -T. Вы можете видеть это из вывода:

/aaa/?acl
* About to connect() to 192.168.57.101 port 80 (#0)
*   Trying 192.168.57.101...
* Connected to 192.168.57.101 (192.168.57.101) port 80 (#0)
> PUT /aaa/?acl HTTP/1.1
> User-Agent: curl/7.29.0
> Host: 192.168.57.101
> Accept: */*
> Date: Thu, 18 Aug 2016 08:01:44 GMT
> Content-Type: application/x-www-form-urlencoded; charset=utf-8
> Authorization: AWS WFBZ1S6SO0DZHW2LRM6U:r84lr/lPO0JCpfk5M3GRJfHdUgQ=
> Content-Length: 323
> Expect: 100-continue
>
< HTTP/1.1 100 CONTINUE
HTTP/1.1 100 CONTINUE

* We are completely uploaded and fine
< HTTP/1.1 200 OK
HTTP/1.1 200 OK
< x-amz-request-id: tx00000000000000000001f-0057b56b69-31d42-default
x-amz-request-id: tx00000000000000000001f-0057b56b69-31d42-default
< Content-Type: application/xml
Content-Type: application/xml
< Content-Length: 0
Content-Length: 0
< Date: Thu, 18 Aug 2016 08:01:45 GMT
Date: Thu, 18 Aug 2016 08:01:45 GMT

<
* Connection #0 to host 192.168.57.101 left intact

если параметры URL содержат специальные символы, такие как «+», используйте --data-urlencode для каждого параметра (содержащего специальные символы):

curl -G -H "Accept:..." -H "..." --data-urlencode "beginTime=${time}+${zone}" --data-urlencode "endTime=${time}+${zone}" "${url}"
Тийна
источник
57

HTTP-параметры являются частью URL:

"http://localhost/?name=value&othername=othervalue"

Обычная аутентификация имеет отдельную опцию, нет необходимости создавать собственный заголовок:

-u "user:password"

«Тело» POST может быть отправлено через --data(для application/x-www-form-urlencoded) или --form(для multipart/form-data):

-F "foo=bar"                  # 'foo' value is 'bar'
-F "foo=<foovalue.txt"        # the specified file is sent as plain text input
-F "foo=@foovalue.txt"        # the specified file is sent as an attachment

-d "foo=bar"
-d "foo=<foovalue.txt"
-d "foo=@foovalue.txt"
-d "@entirebody.txt"          # the specified file is used as the POST body

--data-binary "@binarybody.jpg"

Итак, подведем итог:

curl -d "this is body" -u "user:pass" "http://localhost/?ss=ss&qq=11"
grawity
источник
@ Эмерсон: так и должно быть; Кажется, что в модуле PHP есть все функции, которые есть в исходном C libcurl, и вышеописанное является довольно простой функцией. Однако я не знаю точную функцию для использования. Если вы не можете найти его, спросите о переполнении стека.
Гравитация