2010-11-21 54 views
58

Me pregunto si alguien puede compartir conmigo un ejemplo de multipart/form-data que contiene:Ejemplo multipart/form-data

  1. Algunos parámetros de forma
  2. archivos múltiples
+1

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

+0

posible duplicado de [¿Cómo debería ser una solicitud HTTP de varias partes con varios archivos?] (http://stackoverflow.com/questions/913626/what-should-a-multipart-http-request- with-multiple-files-look-like) –

+1

Vaya aquí: http://www.w3.org/TR/html401/interact/forms.html#h-17.13.4 En '17.13.4 Tipos de contenido de formularios' Encontrará lo que busca. –

Respuesta

77

EDIT: Estoy manteniendo una respuesta similar, pero más en profundidad en: https://stackoverflow.com/a/28380690/895245

Para ver exactamente lo que está sucediendo, u se nc -l o un servidor ECHO y un agente de usuario como un navegador o cURL.

Guarde el formulario a un archivo .html:

<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> 

crear archivos a subir

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

Run:

nc -l localhost 8000 

Abra el HTML en el navegador, seleccione los archivos y haga clic en enviar y verifique la terminal.

nc imprime la solicitud recibida. Firefox envió:

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, rizo debe enviar la misma petición POST como su forma navegador:

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

Usted puede hacer varias pruebas con:

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

Cosas desagradables y no inmediatamente evidentes: 'boundary = --------------------------- 9051914041544843365972754266' es * dos guiones más cortos * luego el límites reales en los datos. Esto es realmente, ** realmente ** difícil de ver con todos los guiones enhebrados. –

3

Muchas gracias a @ ¡Ciro Santilli responde! Descubrí que su elección de límite es bastante "infeliz" porque todos los guiones: de hecho, como @Fake Name comentó, cuando utiliza su límite dentro de la solicitud, viene con dos guiones más en el frente:

Ejemplo:

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-- 

he encontrado on this w3.org page que es posible incapsulate cabecera multipart/mixed en un/form-data de varias partes, sólo tiene que elegir otra serie de límite dentro de varias partes/mixto y el uso que uno de incapsulate datos. Al final, debe "cerrar" todos los límites utilizados con el fin FILO para cerrar la solicitud POST (como:

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-- 

Tome una mirada en el enlace anterior

+0

¿Por qué no separa todas las propiedades en 'Content-Disposition' con'; '? – kelin