Es
el protocolo usado en cada transacción de la World Wide
Web que se encarga de procesar y dar respuestas a las peticiones
para visualizar una página web.
HTTP fue desarrollado por el World Wide Web Consortium y la Internet Engineering Task Force,
colaboración que culminó en 1999 con la publicación de una serie de RFC (petición de comentarios: serie de notas sobre Internet,
y sobre sistemas que se conectan a internet). HTTP define la sintaxis y la
semántica que utilizan los elementos de software de la arquitectura web
(clientes, servidores, proxies) para comunicarse.
Hay
una versión de http para la transferencia segura de información llamada https que puede utilizar cualquier método de cifrado
siempre que sea entendido tanto por el servidor como por el cliente.
HTTP
es un protocolo sin estado, es decir, que no guarda ninguna información sobre
conexiones anteriores. El desarrollo de aplicaciones web necesita
frecuentemente mantener estado. Para esto se usan las cookies, que es
información que un servidor puede almacenar en el sistema cliente. Esto le
permite a las aplicaciones web instituir la noción de sesión, y también permite
rastrear usuarios ya que las cookies pueden guardarse en el cliente por tiempo
indeterminado.
Transacciones HTTP:
Una
transacción HTTP está
formada por un encabezado seguido, opcionalmente, por una línea en blanco y
algún dato. El encabezado especificará cosas como la acción requerida del
servidor, o el tipo de dato retornado, o el código de estado.
El
uso de campos de encabezados enviados en las transacciones HTTP le dan gran
flexibilidad al protocolo. Estos campos permiten que se envíe información
descriptiva en la transacción, permitiendo así la autenticación, cifrado e
identificación de usuario.
El
servidor puede excluir cualquier encabezado que ya esté procesado. El servidor
puede elegir excluir alguno o todos los encabezados, si incluirlos, si se
excede algún límite del entorno de sistema.
- HTTP_ACCEPT. Los tipos MIME que el cliente aceptará, dados los encabezados HTTP.
- HTTP_USER_AGENT. El navegador que utiliza el cliente para realizar la petición. El formato general para esta variable es: software/versión biblioteca/versión.
El servidor envía al cliente:
- Un código de estado que indica si la petición fue correcta o no. Los códigos de error típicos indican que el archivo solicitado no se encontró, que la petición no se realizó de forma correcta o que se requiere autenticación para acceder al archivo.
- La información propiamente dicha. Como HTTP permite enviar documentos de todo tipo y formato, es ideal para transmitir multimedia, como gráficos, audio y video. Esta libertad es una de las mayores ventajas de HTTP.
- Información sobre el objeto que se retorna.
HTTP define 8 métodos que indica la acción que desea que se efectúe sobre el recurso identificado.
- HEAD
Pide una
respuesta idéntica a la que correspondería a una petición GET, pero sin el
cuerpo de la respuesta. Esto es útil para la recuperación de meta-información
escrita en los encabezados de respuesta, sin tener que transportar todo el
contenido.
- GET
Pide una
representación del recurso especificado. Por seguridad no debería ser usado por aplicaciones que causen efectos ya que
transmite información a través de la URI agregando parámetros a la URL.
Ejemplo:
GET
/images/logo.png HTTP/1.1 obtiene un recurso llamado logo.png
Ejemplo con
parámetros:
/index.php?page=main&lang=es
- POST
Somete los
datos a que sean procesados para el recurso identificado. Los datos se
incluirán en el cuerpo de la petición. Esto puede resultar en la creación de un
nuevo recurso o de las actualizaciones de los recursos existentes o ambas
cosas.
- PUT
Sube, carga
o realiza un upload de un recurso especificado (archivo), es el camino más
eficiente para subir archivos a un servidor, esto es porque en POST utiliza un mensaje multiparte y el mensaje es
decodificado por el servidor. En contraste, el método PUT te permite escribir
un archivo en una conexión socket establecida con el servidor.
La
desventaja del método PUT es que los servidores de hosting compartido no lo
tienen habilitado.
Ejemplo:
PUT /path/filename.html HTTP/1.1
- DELETE
Borra el
recurso especificado.
- TRACE
Este método
solicita al servidor que envíe de vuelta en un mensaje de respuesta, en la
sección del cuerpo de entidad, toda la data que reciba del mensaje de
solicitud. Se utiliza con fines de comprobación y diagnóstico.
- OPTIONS
Devuelve los
métodos HTTP que el servidor soporta para un URL específico. Esto puede ser
utilizado para comprobar la funcionalidad de un servidor web mediante petición
en lugar de un recurso específico.
- CONNECT
Se utiliza
para saber si se tiene acceso a un host, bajo condiciones especiales, como por
ejemplo "corrientes" de datos bidireccionales encriptados (como lo
requiere SSL).
No hay comentarios:
Publicar un comentario