Baseline Widely available
El método HTTP POST
envÃa datos al servidor. El tipo del cuerpo de la solicitud es indicada por la cabecera Content-Type
.
La diferencia entre PUT
y POST
es que PUT
es idempotente: llamarlo una o varias veces sucesivamente tiene el mismo efecto (no tiene efecto secundario // colateral), mientras que varios POST
idénticos pueden tener efectos adicionales, como pasar una orden muchas veces.
Una solicitud POST
es tipicamente enviada por un formulario HTML y resulta en un cambio en el servidor. En este caso, el tipo de contenido es seleccionado poniendo la cadena de texto adecuada en el atributo enctype
del elemento <form>
o el atributo formenctype
de los elementos <input>
o <button>
:
application/
x-www-form-urlencoded
: Los valores son codificados en tuplas llave-valor separadas por '&'
, con un '='
entre la llave y el valor. Caracteres no-Alfanumericos en ambas (llaves, valores) son percent encoded: Esta es la razón por la cual este tipo no es adecuado para usarse con datos binarios (use multipart/form-data
en su lugar)multipart/form-data
: Cada valor es enviado como un dato de bloque ("input de un formulario"), con un delimitador como separador definido por el usuario ("espacio entre campos"). Ãstas llaves son colocadas en el Content-Disposition , la cual es cómo está estructurada cada parte del HEADER en una petición HTTPtext/plain
Cuando la solicitud POST
es enviada por otro método distinto a un formulario HTML â por ejemplo mediante una XMLHttpRequest
â el cuerpo puede aceptar cualquier tipo. Como se describe en la especificación HTTP 1.1, el método POST
está diseñado para permitir un método uniforme que cubra las siguientes funciones:
Un formulario simple empleando el tipo de contenido por defecto application/x-www-form-urlencoded
:
POST / HTTP/1.1
Host: foo.com
Content-Type: application/x-www-form-urlencoded
Content-Length: 13
say=Hi&to=Mom
Un formulario usando el tipo de contenido multipart/form-data
:
POST /test.html HTTP/1.1
Host: example.org
Content-Type: multipart/form-data;boundary="boundary"
--boundary
Content-Disposition: form-data; name="field1"
value1
--boundary
Content-Disposition: form-data; name="field2"; filename="example.txt"
value2
Especificaciones Compatibilidad con navegadores Ver también
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4