Jak wyświetlasz dane POST za pomocą cURL?

139

Na przykład POST do serwera WWW z argumentem -v:

curl -v http://testserver.com/post -d "firstname=john&lastname=doe"

I wynik

> POST /post HTTP/1.1
> User-Agent: curl/7.19.7 (universal-apple-darwin10.0) libcurl/7.19.7 OpenSSL/0.9.8l zlib/1.2.3
> Host: testserver.com
> Accept: */*
> Content-Length: 28
> Content-Type: application/x-www-form-urlencoded
> 
< HTTP/1.1 200 OK
(etc)

Nie ma wzmianki o danych, które opublikowałem.

Czy istnieje opcja w cURL, aby wyświetlić ciąg „firstname = john i nazwisko = doe” na wyjściu?

Uwaga: Oczywiście ciąg, który chcę, znajduje się w poleceniu, które wykonałem, ale istnieje kilka innych opcji wysyłania, takich jak --form i --data-ascii itp. Chciałbym zobaczyć surowe dane wysyłane na serwer.

gak
źródło
1
Możesz także uruchomić tcpdump, aby przechwycić rzeczywiste dane wysyłane na serwer. Lub wireshark (lepiej), jeśli masz.
Keith
Nie jestem pewien, czy potrafisz. Czy to przykład bezpieczeństwa przez zaciemnienie? - stackoverflow.com/questions/198462/…
slotishtype

Odpowiedzi:

175

Najbliższe, które dostałem bez użycia, tcpdumpto skorzystanie z --trace-asciiopcji:

~ curl http://w3.org/ -d "hello=there" --trace-ascii /dev/stdout
== Info: About to connect() to w3.org port 80 (#0)
== Info:   Trying 128.30.52.45... == Info: connected
== Info: Connected to w3.org (128.30.52.45) port 80 (#0)
=> Send header, 210 bytes (0xd2)
0000: POST / HTTP/1.1
0011: User-Agent: curl/7.19.7 (universal-apple-darwin10.0) libcurl/7.1
0051: 9.7 OpenSSL/0.9.8l zlib/1.2.3
0070: Host: w3.org
007e: Accept: */*
008b: Content-Length: 11
009f: Content-Type: application/x-www-form-urlencoded
00d0: 
=> Send data, 11 bytes (0xb)
0000: hello=there

Niestety nie działa to, gdy publikujesz multipart/form-data:

~ curl http://w3.org/ -F hello=there -F testing=123 --trace-ascii /dev/stdout
== Info: About to connect() to w3.org port 80 (#0)
== Info:   Trying 128.30.52.45... == Info: connected
== Info: Connected to w3.org (128.30.52.45) port 80 (#0)
=> Send header, 270 bytes (0x10e)
0000: POST / HTTP/1.1
0011: User-Agent: curl/7.19.7 (universal-apple-darwin10.0) libcurl/7.1
0051: 9.7 OpenSSL/0.9.8l zlib/1.2.3
0070: Host: w3.org
007e: Accept: */*
008b: Content-Length: 244
00a0: Expect: 100-continue
00b6: Content-Type: multipart/form-data; boundary=--------------------
00f6: --------19319e4d1b79
010c: 
<= Recv header, 32 bytes (0x20)
0000: HTTP/1.1 301 Moved Permanently
gak
źródło
4
Wiem, że to twoja własna odpowiedź, ale myślę, że możesz zaakceptować to jako poprawną odpowiedź. I tak to rozwiązało, dzięki :-)
Darren Cook
4
Usuń dowolne -vlub --verbosezastępujące dyrektywę śledzenia.
AlikElzin-kilaka
2
@AugustinRiedinger Działa dobrze z https. Właśnie spróbowałem i zobaczyłem ładowność. Dane są szyfrowane, ale ponieważ jesteś punktem końcowym połączenia, masz wszystkie dostępne dane, dlatego curl może je zobaczyć.
gak
2
Korzystanie --trace-asciidziałało dla mnie w systemie OS X 10.8.5 Mountain Lion. Przesłałem wieloczęściowy obiekt z dwoma obrazami i ciałem Jsona i wszystko działało zgodnie z oczekiwaniami
Heath Borders
4
Zamiast --trace-ascii /dev/stdoutciebie możesz --trace-ascii -(myślnik)
Adam Michalik
27

Lub możesz przetestować za pomocą https://httpbin.org/

$ curl https://httpbin.org/post -d "firstname=john&lastname=doe"
{
  "args": {}, 
  "data": "", 
  "files": {}, 
  "form": {
    "firstname": "john", 
    "lastname": "doe"
  }, 
  "headers": {
    "Accept": "*/*", 
    "Content-Length": "27", 
    "Content-Type": "application/x-www-form-urlencoded", 
    "Host": "httpbin.org", 
    "User-Agent": "curl/7.43.0"
  }, 
  "json": null, 
  "origin": "78.228.163.126", 
  "url": "https://httpbin.org/post"
}
Christophe Morio
źródło
12

Chciałbym dodać alternatywę netcat

#!/bin/bash
nc -l 8080 &

curl "http://localhost:8080" \
-H "Accept: application/json" \
-H "Content-Type: application/json" \
--data @<(cat <<EOF
{
  "me": "$USER",
  "something": $(date +%s)
}
EOF
)
Gert Cuykens
źródło
9

Możesz użyć Charlesa i curl --proxy localhost:8888. Simples!

Dori
źródło
4
nie, to nie działa z https. Zaakceptowana odpowiedź jest w porządku i łatwiejsza.
akostadinov
httpsnie było wymogiem w pytaniu: p
Dori
@CasparHarmer jaki jest twój prob z zaakceptowaną odpowiedzią? jeśli potrzebujesz więcej, TCPdump załatwia sprawę.
Gewure,
Stało się to 3 lata temu. Nie pamiętam.
Caspar Harmer