2010-11-21 11 views
58

Ich frage mich, ob jemand mit mir ein Beispiel für multipart/form-data teilen können, die enthält:Beispiel für multipart/form-data

  1. Einige Formularparameter
  2. Mehrere Dateien
+1

Siehe http:. //www.htmlcodetutorial. com/forms/form_enctype.html –

+0

mögliche Duplikate von [Wie sollte eine Multipart HTTP-Anfrage mit mehreren Dateien aussehen?] (http://stackoverflow.com/questions/913626/what-should-a-multipart-http-request- with-multiple-files-like-like) –

+1

Gehen Sie hier: http://www.w3.org/TR/html401/interact/forms.html#h-17.13.4 In '17.13.4 Form Content-Typen' Sie Ich werde finden, was Sie suchen. –

Antwort

77

EDIT: ich bin die Aufrechterhaltung einer ähnlichen, aber tiefer gehende Antwort auf: https://stackoverflow.com/a/28380690/895245

genau zu sehen, was, u geschieht se nc -l oder ein ECHO Server und ein User Agent wie ein Browser oder cURL.

Speichern Sie das Formular an eine .html Datei:

<form action="http://localhost:8000" method="post" enctype="multipart/form-data"> 
    <p><input type="text" name="text" value="text default"> 
    <p><input type="file" name="file1"> 
    <p><input type="file" name="file2"> 
    <p><button type="submit">Submit</button> 
</form> 

Dateien erstellen laden:

echo 'Content of a.txt.' > a.txt 
echo '<!DOCTYPE html><title>Content of a.html.</title>' > a.html 

Run:

nc -l localhost 8000 

Öffnen Sie die HTML-Datei auf Ihrem Browser, wählen Sie die Dateien und klicken Sie auf Senden und überprüfen Sie das Terminal.

nc druckt die Anfrage erhalten. Firefox gesendet:

POST/HTTP/1.1 
Host: localhost:8000 
User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux i686; rv:29.0) Gecko/20100101 Firefox/29.0 
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 
Accept-Language: en-US,en;q=0.5 
Accept-Encoding: gzip, deflate 
Cookie: __atuvc=34%7C7; permanent=0; _gitlab_session=226ad8a0be43681acf38c2fab9497240; __profilin=p%3Dt; request_method=GET 
Connection: keep-alive 
Content-Type: multipart/form-data; boundary=---------------------------9051914041544843365972754266 
Content-Length: 554 

-----------------------------9051914041544843365972754266 
Content-Disposition: form-data; name="text" 

text default 
-----------------------------9051914041544843365972754266 
Content-Disposition: form-data; name="file1"; filename="a.txt" 
Content-Type: text/plain 

Content of a.txt. 

-----------------------------9051914041544843365972754266 
Content-Disposition: form-data; name="file2"; filename="a.html" 
Content-Type: text/html 

<!DOCTYPE html><title>Content of a.html.</title> 

-----------------------------9051914041544843365972754266-- 

Aternativelly, cURL sollte die gleiche POST-Anfrage als einen Browser Formular senden:

nc -l localhost 8000 
curl -F "text=default" -F "[email protected]" -F "[email protected]" localhost:8000 

Sie können mit mehreren Tests durchführen:

while true; do printf '' | nc -l localhost 8000; done 
+12

Obnoxious und nicht sofort offensichtlich Zeug: "Grenze = --------------------------- 9051914041544843365972754266" ist * zwei Bindestriche kürzer * dann die tatsächliche Grenzen in den Daten. Das ist wirklich, wirklich schwer zu sehen mit all den Bindestrichen aneinandergereiht. –

3

Vielen Dank an @ Ciro Santilli Antwort! Ich fand, dass seine Wahl für Grenze ziemlich "unglücklich" ist, weil alle Bindestriche: in der Tat, wie @Fake Name kommentierte, wenn Sie Ihre Grenze innerhalb der Anfrage verwenden, kommt es mit zwei Bindestrichen auf der Vorderseite:

Beispiel:

POST/HTTP/1.1 
HOST: host.example.com 
Cookie: some_cookies... 
Connection: Keep-Alive 
Content-Type: multipart/form-data; boundary=12345 

--12345 
Content-Disposition: form-data; name="sometext" 

some text that you wrote in your html form ... 
--12345 
Content-Disposition: form-data; name="name_of_post_request" filename="filename.xyz" 

content of filename.xyz that you upload in your form with input[type=file] 
--12345 
Content-Disposition: form-data; name="image" filename="picture_of_sunset.jpg" 

content of picture_of_sunset.jpg ... 
--12345-- 

fand ich on this w3.org page, die möglich ist multipart/mixed-Header in einer multipart/form-data auf incapsulate, einfach in multipart/mixed eine andere Grenze Zeichenfolge wählen und dass man unter Verwendung von Daten incapsulate. Am Ende müssen Sie auf „Schließen“ alle Grenz in FILO verwendet, um die POST-Anforderung zu schließen (wie:

POST/HTTP/1.1 
... 
Content-Type: multipart/form-data; boundary=12345 

--12345 
Content-Disposition: form-data; name="sometext" 

some text sent via post... 
--12345 
Content-Disposition: form-data; name="files" 
Content-Type: multipart/mixed; boundary=abcde 

--abcde 
Content-Disposition: file; file="picture.jpg" 

content of jpg... 
--abcde 
Content-Disposition: file; file="test.py" 

content of test.py file .... 
--abcde-- 
--12345-- 

Schauen Sie oben auf den Link

+0

Warum trennen Sie nicht alle Eigenschaften in 'Content-Disposition' mit'; '? – kelin