𝖂𝖎ƙ𝖎𝖊

Hypertext Transfer Protocol: mudanças entre as edições

imported>Vini6305
(Desfeita a edição 64183490 de Jonathan Jose Miodutzki)
 
(945 edições intermediárias de mais de 100 usuários não estão sendo mostradas)
Linha 1: Linha 1:
{{Reciclagem}}
{{Pilha de protocolos TCP/IP}}
{{Wikificação}}
O '''{{lang|en|Hypertext Transfer Protocol}}''', sigla '''HTTP''' (em português '''Protocolo de Transferência de Hipertexto''') é um [[protocolo de comunicação]] (na [[camada de aplicação]] segundo o [[Modelo OSI]]) utilizado para sistemas de informação de [[hipermídia]], distribuídos e colaborativos.<ref name="T. Berners-Lee et all, 1996">T. Berners-Lee et all, 1996</ref> Ele é a base para a comunicação de dados da [[World Wide Web]].
{{ProtocolosIP}}
'''HTTP''' significa ''[[hipertexto|HyperText]] Transfer Protocol'' (Protocolo de Transferência de Hipertexto) e é um protocolo da camada de Aplicação do modelo OSI utilizado para transferência de dados na [[World Wide Web]]. Esse é o protocolo da World Wide Web (www).Ele transfere dados de hiper midia(imagens,sons e textos).Algumas de suas características é que geralmente esse protocolo utiliza a porta 80 e ele é usado para a comunicação dos sites.Ele se comunica na linguágem HTML(Hipertext Markup Language), mas para os computadores se comunicarem com o servidor do site,tem que usar alguns comandos próprios dele,que não são o HTML.


[[Hipertexto]] é o texto estruturado que utiliza ligações lógicas ([[hiperlink]]s) entre [[nó]]s contendo texto. O HTTP é o protocolo para a troca ou transferência de hipertexto.


Para você acessar um outro documento no documento atual que você está acessando,tem uma ancora que liga os documentos,chamada de link(ou ancora),e esses documentos estão em um site e para acessá-lo você tem que digitar o seu endereço que se chama URI (Universal Resource Indentifier),mas não confundam URI com URL(Universal Resource Local),que é o método do HTML de ligar documentos.
Coordenado pela [[World Wide Web Consortium]] e a [[Internet Engineering Task Force]], culminou na publicação de uma série de ''[[Request for Comments|Requests for Comments]]''; mais notavelmente o RFC 2616, de junho de 1999, que definiu o HTTP/1.1. Em Junho de 2014 foram publicados 6 RFC's para maior clareza do protocolo HTTP/1.1.<ref>{{citar web|URL = https://www.mnot.net/blog/2014/06/07/rfc2616_is_dead|título = RFC2016 está morto|data = 7 de Junho de 2014|acessadoem = 13 de junho de 2015|autor = Mark Nottingham|publicado = Mark Nottingham|língua = inglês}}</ref> Em Março de 2015, foi divulgado o lançamento do [[HTTP/2]]. A atualização deixará o navegador com um tempo de resposta melhor e mais seguro. Ele também melhorará a navegação em smartphones.<ref>{{citar web|URL = http://www.psafe.com/blog/http2-internet-mais-rapida/|título = HTTP/2: Internet mais rápida|data = |acessadoem = |autor = |publicado = }}</ref> Os trabalhos no [[HTTP/3]] já começaram e suas versões beta estão em teste por grandes empresas.<ref>{{citar web|URL = https://quicwg.org/base-drafts/draft-ietf-quic-http.html|título = Hypertext Transfer Protocol Version 3 (HTTP/3)|data = |acessadoem = |autor = |publicado = }}</ref>


==Considerações iniciais==
Para acedermos a outro documento a partir de uma palavra presente no documento actual podemos utilizar [[hiperligação|hiperligações]] (ou âncoras). Estes documentos se encontram no sítio com um endereço de página da [[Internet]] – e para acessá-los deve-se digitar o respectivo endereço, denominado [[URI]] (''Universal Resource Identifier'' ou Identificador Universal de Recurso), que não deve ser confundido com [[URL]] (''Universal Resource Locator'' ou Localizador Universal de Recurso), um tipo de URI que pode ser directamente localizado.


O HyperText Transfer Protocol (HTTP) é um protocolo de rede responsável pela transferência de dados e pela comunicação entre cliente e servidor na World Wide Web (WWW). O protocolo HTTP surgiu da necessidade de distribuir informações pela Internet. Para que essa distribuição fosse possível, foi necessário criar uma forma padronizada de comunicação entre os clientes e os servidores da Web. Com isso, o protocolo HTTP passou a ser utilizado para a comunicação entre computadores na Internet e a especificar como seriam realizadas as transações entre clientes e servidores, através do uso de regras básicas (cf. EMBRATEL, HTTP. Disponível em:
== Visão técnica geral ==
http://www.embratel.net.br/internet/tecnologia/tecnologia/protocolos_http.html Acesso em: 15 fev. 2002).
Este protocolo tem sido usado pela WWW desde 1990. A primeira versão de HTTP, chamado HTTP/0.9, era um protocolo simples para a transferência de dados no formato de texto ASCII pela Internet, através de um único método de requisição, chamado GET. A versão HTTP/1.0 foi desenvolvida, entre 1992 e 1996, para suprir a necessidade de transferir não apenas texto. Com essa versão, o protocolo passou a transferir mensagens do tipo MIME44 (Multipurpose Internet Mail Extension) e foram implementados novos métodos de requisição, chamados POST e HEAD.
No HTTP/1.1, versão atual do protocolo descrito na RFC 2616 por Fielding et al (1999, p. 7) foi desenvolvido um conjunto de implementações adicionais ao HTTP/1.0, como por exemplo: o uso de conexões persistentes; o uso de servidores proxy que permite uma melhor organização da cache; novos métodos de requisições; entre outros. Fielding et al (1999, p. 7) afirma que o HTTP também é usado como um protocolo genérico para comunicação entre os agentes de usuários e proxies/gateways com outros protocolos, como o SMTP, NNTP, FTP, Gopher, e WAIS, permitindo o acesso a recursos disponíveis em aplicações diversas.


==Funcionamento do protocolo HTTP==


Um sistema de comunicação em rede possui diversos protocolos que trabalham cooperativamente para o fornecimento de serviços. Para que o protocolo HTTP consiga transferir seus dados pela Web, é necessário que os protocolos TCP e IP (Internet Protocol) tornam possível a conectividade entre clientes e servidores através de sockets TCP/IP.
O HTTP funciona como um protocolo de [[requisição-resposta]] no modelo computacional [[cliente-servidor]]. Um [[navegador web]], por exemplo, pode ser o ''cliente'' e uma aplicação em um computador que [[Host|hospeda]] um [[sítio da web]] pode ser o ''servidor''. O cliente submete uma mensagem de ''requisição'' HTTP para o servidor. O servidor, que fornece os ''recursos'', como arquivos [[HTML]] e outros conteúdos, ou realiza outras funções de interesse do cliente, retorna uma mensagem ''resposta'' para o cliente. A resposta contém informações de estado completas sobre a requisição e pode também conter o conteúdo solicitado no corpo de sua mensagem.
De acordo com Fielding et al (1999, p. 10), o HTTP utiliza o modelo cliente-servidor, como a maioria dos protocolos de rede, baseando-se no paradigma de requisição e resposta. Um programa requisitante (cliente) estabelece uma conexão com um outro programa receptor(servidor) e envia uma requisição para o servidor na forma de um método de requisição, contendo a URI (Uniform Resource Identifiers), a versão do protocolo, uma mensagem MIME (Padrão utilizado para codificar dados em formato de textos ASCII para serem transmitidos pela Internet) contendo os modificadores da requisição, informações sobre o cliente e, possivelmente, o conteúdo no corpo da mensagem.
O servidor responde com uma linha de status (status line) incluindo sua versão de protocolo e um código de operação bem sucedida ou um código de erro, seguido pelas informações do servidor, metainformações da entidade e possível conteúdo no corpo da mensagem, após enviar a resposta encerra-se a conexão
estabelecida.


==Mensagem http==
Um navegador web é um exemplo de [[agente de usuário]] (AU). Outros tipos de agentes de usuário incluem o software de indexação usado por provedores de consulta ([[web crawler]]), [[Navegador por voz|navegadores vocais]], [[Aplicação móvel|aplicações móveis]] e outros software que acessam, consomem ou exibem conteúdo web.


O protocolo HTTP faz a comunicação entre o cliente e o servidor através de
O HTTP é projetado para permitir intermediações de elementos de rede para melhorar ou habilitar comunicações entre clientes e servidores. Sites web de alto tráfego geralmente se beneficiam dos servidores de [[cache web]] que entregam conteúdo em nome de [[Servidor upstream|servidores de upstream]] para melhorar o tempo de resposta. Navegadores web armazenam os recursos web acessados anteriormente e reutilizam-nos quando possível para reduzir o tráfego de rede. [[Servidores proxy]] HTTP nas fronteiras de [[Rede privada|redes privadas]] podem facilitar a comunicação para o cliente sem um endereço globalmente roteável, transmitindo mensagens com servidores externos.
mensagens. O cliente envia uma mensagem de requisição de um recurso e o servidor envia uma mensagem de resposta ao cliente com a solicitação. Segundo Foscarini (2001, p. 13), os dois tipos de mensagens existentes no protocolo, utilizam um formato genérico, definido na RFC 822, para a transferência de entidades .
Uma mensagem tanto de requisição quanto de resposta é composta, conforme definido na RFC 2616 (Fielding et al, 1999, p. 21), por uma linha inicial, nenhuma ou mais linhas de cabeçalhos, uma linha em branco obrigatória finalizando o cabeçalho, e por fim o corpo da mensagem podendo ser opcional em determinados casos. Nesta seção serão apresentados os campos que compõem uma mensagem mais detalhadamente. A Figura 1 ilustra um exemplo de mensagens de requisição e resposta.
[[Imagem:telnet.jpg]]


Basicamente, o HTTP define como clientes Web requisitam páginas Web aos servidores e como elas as transferem a clientes. Quando um usuário solicita uma página Web (acessa uma URL), o navegador envia ao servidor mensagens de requisição HTTP para os objetos da página. O servidor, por sua vez, recebe estas requisições e responde com mensagens de resposta HTTP que contém os objetos (...). O protocolo HTTP utiliza por padrão a porta 80 para comunicação (MACEDO et al., 2018).<ref>{{citar livro|título=REDES DE COMPUTADORES|ultimo=Macedo|primeiro=Ricardo, Tombesi|ano=2018|local=Santa Maria|página=139}}</ref>


==Cabeçalho da mensagem==
== História ==
[[Imagem:Tim Berners-Lee CP 2.jpg|thumb|[[Tim Berners-Lee]] na [[Campus Party Brasil]] em 2009.]]
O HyperText Transfer Protocol é um protocolo de aplicação responsável pelo tratamento de pedidos e respostas entre cliente e servidor na [[World Wide Web]]. Ele surgiu da necessidade de distribuir informações pela [[Internet]] e para que essa distribuição fosse possível foi necessário criar uma forma padronizada de comunicação entre os clientes e os servidores da Web e entendida por todos os computadores ligados à Internet. Com isso, o protocolo HTTP passou a ser utilizado para a comunicação entre computadores na Internet e a especificar como seriam realizadas as transacções entre clientes e servidores, através do uso de regras básicas.


O cabeçalho da mensagem, identificado como header, é utilizado para transmitir informações adicionais entre o cliente e o servidor. O header é especificado imediatamente após a linha inicial da transação (método), tanto para a requisição do cliente quanto para a resposta do servidor, seguido de dois pontos (:) e um valor. Existem quatro tipos de cabeçalhos que poderão ser incluídos na mensagem os quais são: general-header, requestheader, response-header e entity-header (cf. Fielding et al, 1999, p. 21).
Este protocolo tem sido usado pela WWW desde [[1990]]. A primeira versão de HTTP, chamada HTTP/0.9, era um protocolo simples para a transferência de dados no formato de texto [[ASCII]] pela Internet, através de um único método de requisição, chamado <code>GET</code>. A versão HTTP/1.0 foi desenvolvida entre [[1992]] e [[1996]] para suprir a necessidade de transferir não apenas texto. Com essa versão, o protocolo passou a transferir mensagens do tipo [[MIME|MIME44]] (''Multipurpose Internet Mail Extension'') e foram implementados novos métodos de requisição, chamados <code>POST</code> e <code>HEAD</code>.
Estes cabeçalhos são utilizados para enviar informações adicionais sobre a mensagem transmitida (general-header), a requisição e os clientes (request-header) que comunicam suas configurações e os formatos de documentos desejados como resposta (cf. Bastos & Ladeira, 2001). Além disso, são utilizados pelo servidor ao retornar o recurso no qual foi requisitado pelo cliente, para transmitir informações que descrevem as configurações do servidor e do recurso identificado pelo URI de requisição, e que não pertence à linha de status (responseheader).
Na RFC 2616 (cf. Fielding et al, 1999) estão descritos todos os campos que pertencem a estes cabeçalhos.  


==1.1 Corpo da mensagem==
No HTTP/1.1, versão do protocolo descrito na RFC 2616,<ref name="Fielding et al 1999, p. 7">Fielding et al 1999, p. 7</ref> foi desenvolvido um conjunto de implementações adicionais ao HTTP/1.0, como por exemplo: o uso de conexões persistentes; o uso de servidores ''[[proxy]]'' que permitem uma melhor organização da ''[[cache]]''; novos métodos de requisições; entre outros. Afirma-se que o HTTP também é usado como um protocolo genérico para comunicação entre os agentes de utilizadores e ''proxies''/''gateways'' com outros protocolos, como o [[SMTP]], [[NNTP]], [[FTP]], [[Gopher]], e [[WAIS]], permitindo o acesso a recursos disponíveis em aplicações diversas.<ref name="Fielding et al 1999, p. 7"/>


Uma mensagem HTTP pode conter um corpo de dados que são enviados abaixo das linhas de cabeçalho. Em uma mensagem de resposta, o corpo da mensagem é o recurso que foi requisitado pelo cliente, ou uma mensagem de erro caso este recurso não seja possível. Já em uma mensagem de requisição, o corpo pode conter dados que serão enviados diretamente pelo usuário ou um arquivo que será enviado para o servidor.
O [[HTTP/2]] foi publicado como RFC 7540 em maio de 2015.
Quando uma mensagem HTTP tiver um corpo, poderão ser incluídos cabeçalhos de entidades que descrevem suas características, como por exemplo, o Content-Type que informa o tipo MIME dos dados no corpo da mensagem e o Content-Length que informa a quantidade de bytes que o corpo da mensagem contém. A Tabela 2 apresenta alguns tipos MIME.
{| class="wikitable"
|-
!Ano
!Versão do HTTP
|-
|1991
|0.9
|-
|1996
|1.0
|-
|1997
|1.1
|-
|2015
|[[HTTP/2|2.0]]
|-
|2018
|[[HTTP/3|3.0]]
|}


Tabela 2 – Alguns tipos MIME
== Sessão HTTP ==
Uma sessão HTTP é uma sequência de transações de rede de requisição-resposta. Um cliente HTTP inicia uma requisição estabelecendo uma conexão [[Transmission Control Protocol]] (TCP) para uma [[porta]] particular de um servidor (normalmente a porta 80. Veja [[Lista de portas dos protocolos TCP e UDP]]). Um servidor HTTP ouvindo naquela porta espera por uma mensagem de requisição de cliente. Recebendo a requisição, o servidor retorna uma linha de estado, como "HTTP/1.1 200 OK", e uma mensagem particular própria. O corpo desta mensagem normalmente é o recurso solicitado, apesar de uma mensagem de erro ou outra informação também poder ser retornada.


Exemplo        Descrição
== Cookies ==
{{Artigo principal|Cookie HTTP}}
O termo cookie é derivado do inglês que significa biscoito. Recebeu esse nome de uma antiga gíria usada pelos programadores que consistia em um programa que chamava um procedimento e recebia de volta algo que seria necessário apresentar novamente mais tarde para realizar algum trabalho. Foi criado pela Netscape para solucionar o problema do envio e solicitação de arquivos, que eram esquecidos pelo servidor e que poderiam ser usados por outros computadores com o mesmo IP conforme (TANEMBAUM, 2003), o que causava problemas, pois não se sabia na realidade se era ou não aquele usuário mesmo. Os cookies são arquivos ou strings e não são programas executáveis. Eles são tratados como dados pelo navegador, não existe nenhuma maneira dele ser usado como vírus, apesar de que podem ser explorados bugs no servidor e causar a ativação de um cookie como vírus, por um hacker. Basicamente ele é um grupo de dados trocados entre o servidor de páginas e o navegador colocado em um ficheiro criado no computador do usuário. Serve para manter a persistência das sessões HTTP. Ele funciona da seguinte forma: Um usuário solicita uma página da Web, nisso o servidor pode fornecer informações adicionais acompanhando a página solicitada. Essas informações podem incluir um cookie, um pequeno arquivo ou string (com quatro KB no máximo). Este cookie pode ter até 5 campos (figura abaixo): Domain, Path, Content, Expires, Secure. Domain informa de onde veio o cookie. O navegador confirma que os servidores estão enviando dados fieis a respeito de seu domínio. Cada domínio pode armazenar no máximo 20 cookies por cliente. O campo Path é um caminho na estrutura de diretórios do servidor que identifica as partes da árvore de arquivos do servidor que podem usar o cookie. Frequentemente, ele obtém o símbolo / (barra), que representa a árvore inteira. O campo Content utiliza a forma nome = valor, podendo o servidor definir da maneira que quiser tanto o valor quanto o nome, e é nele que fica armazenado o conteúdo do cookie. Expires é o campo que faz o cookie persistir, nele contém a data e o horário, e se ele estiver ausente o navegador descartara automaticamente após o termino da sessão. O último campo define se ele é seguro ou não.
{|
|Domain
|Path
|Content
|Expires
|Secure
|-
|toms-casino.com
|'''/ '''
|CustomerlD=497793521
|15 de outubro de 2002


text/plain- Arquivo no formato texto (ASCII).
17:00
text/html-  Arquivo no formato HTML, utilizado como padrão para documentos Web.
|'''Yes'''
Image/gif-  Imagem com o formato GIF.
Image/jpeg- Imagem com o format JPEG.
application/zip- Arquivo compactado.


|joes-store.com
|'''/'''
|Cart=1-00501;1-07031;2-13721
|11 de outubro de 2002


Fonte: Fielding et al, 1999.
14:22
|'''No'''
|-
|aportal.com
|'''/'''
|Prefs=Stk:SUNW+ORCL;Spt:Jet


s
|31 de dezembro de 2010


==1.2 Requisição==
23:59
|'''No'''
|-
|sneaky.com 31-
|'''/'''
|UserID=3627239101
|12-12


De acordo com Fielding (1999, p. 24), uma mensagem de requisição do cliente é composta pelos seguintes campos: uma linha inicial (Request-Line); linhas de cabeçalhos (Request-header); uma linha em branco obrigatória e um corpo de mensagem opcional. A linha inicial de uma requisição é composta por três partes separadas por espaços: o método (Method), a identificação do URI (Request-URI) e a versão do HTTP (HTTP-Version) utilizado.
23:59
Segundo Bastos & Ladeira ( BASTOS, Leonara de Oliveira; LADEIRA, Adriane Cristina. Protocolo HTTP. Disponível em:
|'''No'''
http://www.comp.ufscar.br/~drica/http.html. Acesso em: 10 fev. 2002) Request-URI é um identificador de recurso uniforme (Uniform Resource Identifier) que identifica sobre qual recurso será aplicada a requisição. No protocolo HTTP, o tipo de URI utilizado é chamado de URL (Uniform Resource Locater), no qual é composto pela identificação do protocolo, pelo endereço do computador servidor e pelo documento requisitado (cf. Embratel, 2002).
|}
Figura x: Alguns exemplos de cookie.↵Fonte: (TANEMBAUM, 2003).


O cookie é usado para identificar um usuário que configurou uma página web, para que na próxima vez que ele entrar ela esteja configurada do modo em que ele deixou. Pode ser usado também quando se faz a solicitação de armazenamento de senha, na vez posterior em que entrar no site, a sua senha será lembrada. É usado também em sites de compra, como e-commerce, armazenando os produtos que o cliente colocou no carrinho para que no final da compra não necessite fazer todo o processo novamente.


==1.2.1 Métodos==
== Funcionamento ==
Um sistema de comunicação em rede possui diversos protocolos que trabalham em conjunto para o fornecimento de serviços. Para que o protocolo HTTP consiga transferir seus dados pela Web, é necessário que os protocolos [[TCP]] e [[IP]] (''Internet Protocol'', Protocolo de Internet) tornem possível a conexão entre clientes e servidores através de ''[[socket]]s'' [[TCP/IP]].


O protocolo HTTP/1.1 possui um conjunto de métodos, definidos na RFC 2616, que são utilizados na requisição de recursos, que são os GET, HEAD, POST, OPTIONS, PUT, DELETE, TRACE, CONNECT. Conforme Bastos & Ladeiras (2001), o método determina o que o servidor deve fazer com o URL fornecido no momento da requisição de um recurso. A seguir, serão detalhados os métodos mais utilizados nas mensagens.
De acordo com Fielding,<ref>Fielding et al (1999, p. 10)</ref> o HTTP utiliza o modelo [[cliente-servidor]], como a maioria dos protocolos de rede, baseando-se no paradigma de requisição e resposta. Um programa requisitante (cliente) estabelece uma conexão com um outro programa receptor (servidor) e envia-lhe uma requisição, contendo a [[URI]], a versão do protocolo, uma mensagem [[MIME]] (padrão utilizado para codificar dados em formato de textos ASCII para serem transmitidos pela Internet) contendo os modificadores da requisição, informações sobre o cliente e, possivelmente, o conteúdo no corpo da mensagem.
O método GET é reconhecido por todos os servidores, sendo utilizado como método padrão para a requisição de recursos por meio do protocolo HTTP. Esse método solicita ao servidor para que encontre e retorne como resposta ao cliente, qualquer dado que estiver identificado pelo URI. A Figura 2a ilustra um exemplo de uma requisição utilizando o método GET.
A utilização do método POST em uma requisição ocorre quando é necessário enviar dados ao servidor para serem processados geralmente por um programa script identificado no Request-URI. Uma requisição por meio desse método sempre requer que as informações submetidas sejam incluídas no corpo da mensagem e formatadas como uma query string, além de conter cabeçalhos adicionais especificando seu tamanho (Content-Lenght) e seu formato (Content-Type). Por isso, esse método oferece uma maior segurança em relação aos dados transferidos, ao contrário do método GET que os dados são anexados a URL, ficando visíveis ao usuário (cf. 46 HERRMANN, Eric. Aprenda em 1 semana programação CGI em Perl 5. Rio de Janeiro: Campus, 1997). A Figura 2b ilustra a utilização deste método.
a)
GET /index.html HTTP/1.0
Accept: text/html
If-modified-since: Sat, 29 Oct 1999 19:43:31 GMT
b)
POST /index.html HTTP/1.0
Accept: text/html
If-modified-since: Sat, 29 Oct 1999 19:43:31 GMT
Content-Type: application/x-www-form-urlencoded
Content-Length: 30
Nome=NamePessoa&Idade=99&Curso=Computacao
Figura 2 – Exemplos de utilização dos métodos GET e POST


O servidor responde com uma linha de status (''status line'') incluindo sua versão de protocolo e com os códigos de erro informando se a operação foi bem sucedida ou fracasso, seguido pelas informações do servidor, [[metainformação|metainformações]] da entidade e possível conteúdo no corpo da mensagem. Após o envio da resposta pelo servidor, encerra-se a conexão estabelecida.


==1.3 Resposta==
== Mensagem HTTP ==
O protocolo HTTP faz a comunicação entre o cliente e o servidor por meio de mensagens. O cliente envia uma mensagem de requisição de um recurso e o servidor envia uma mensagem de resposta ao cliente com a solicitação. Segundo Foscarini,<ref>Foscarini (2001, p. 13)</ref> os dois tipos de mensagens existentes no protocolo utilizam um formato genérico, definido na RFC 822, para a transferência de entidades.


Para Fielding et al (1999, p. 26), uma mensagem de resposta do servidor é composta pelos seguintes campos: uma linha inicial (Status-Line); linhas de cabeçalhos (Responseheader); uma linha em branco obrigatória e um corpo de mensagem opcional. A linha inicial de uma resposta, chamada de linha de status, também possui três partes separadas por espaços: a versão do protocolo HTTP (HTTP-Version), um código de status (Status-Code) da resposta, que fornece o resultado da requisição, e uma frase (Reason-Phrase) de justificativa que descreve o código do status.
Uma mensagem, tanto de requisição quanto de resposta, é composta, conforme definido na RFC 2616,<ref>Fielding et al, 1999, p. 21</ref> por uma linha inicial, nenhuma ou mais linhas de cabeçalhos, uma linha em branco obrigatória finalizando o cabeçalho e por fim o corpo da mensagem, opcional em determinados casos. Nessa sessão serão apresentados os campos que compõem uma mensagem mais detalhadamente; ou seja, o HTTP apresenta o sítio ou local onde está a página da Internet.


=== Cabeçalho da mensagem ===
O cabeçalho da mensagem (''[[header]]'') é utilizado para transmitir informações adicionais entre o cliente e o servidor. Ele é especificado imediatamente após a linha inicial da transação (método), tanto para a requisição do cliente quanto para a resposta do servidor, seguido de dois pontos (:) e um valor. Existem quatro tipos de cabeçalhos que poderão ser incluídos na mensagem os quais são: ''general-header'', ''request-header'', ''response-header'' e ''entity-header''.<ref>cf. Fielding et al, 1999, p. 21</ref>


==1.3.1 Códigos de retorno===
Esses cabeçalhos são utilizados para enviar informações adicionais sobre a mensagem transmitida (''general-header''), a requisição e os clientes (''request-header'') que comunicam suas configurações e os formatos de documentos desejados como resposta.<ref>cf. Bastos & Ladeira, 2001</ref> Além disso, são utilizados pelo servidor ao retornar o recurso no qual foi requisitado pelo cliente, para transmitir informações que descrevem as configurações do servidor e do recurso identificado pelo URI de requisição, e que não pertence à linha de status (''response-header''). Na RFC 2616,<ref>cf. Fielding et al, 1999</ref> estão descritos todos os campos que pertencem a esses cabeçalhos.


O Status-Line de uma resposta HTTP indica ao cliente se sua requisição foi bem sucedida ou não (cf. Herrman, 1997, p. 53). Esta situação é fornecida através de um código de retorno (Status-Code) e uma frase explicativa (Reason-Phrase).
{| class="wikitable" style="position:relative; float:right; margin-left:20px; margin-bottom:20px"
De acordo com Fielding et al (1999, p. 37), o código de status é formado por três
|+ Alguns tipos MIME<ref>Fielding et al, 1999</ref>
dígitos e o primeiro dígito representa a classe que pertence classificada em cinco tipos:  
|-
•  1xx: Informational (Informação) – utilizada para enviar informações para o           cliente deque sua requisição foi recebida e está sendo processada;
! Exemplo !! Descrição
•  2xx: Success (Sucesso) – indica que a requisição do cliente foi bem sucedida;
|-
•  3xx: Redirection (Redirecionamento) – informa a ação adicional que deve ser tomada para completar a requisição;
| text/plain || Arquivo no formato texto (ASCII)
•  4xx: Client Error (Erro no cliente) – avisa que o cliente fez uma requisição que não pode ser atendida;
|-
•  5xx: Server Error (Erro no servidor) – ocorreu um erro no servidor ao cumprir uma requisição válida.
| text/html || Arquivo no formato [[HTML]], utilizado<br />como padrão para documentos Web
|-
| Image/gif || Imagem com o formato [[GIF]]
|-
| Image/jpeg || Imagem com o formato [[JPEG]]
|-
| application/zip || Arquivo [[Compactador de arquivos|compactado]]
|-
| application/json || Arquivo no formato [[JSON]]
|-
| application/xml (ou text/xml)|| Arquivo no formato [[XML]]
|}
 
=== Corpo da mensagem ===
Uma mensagem HTTP pode conter um corpo de dados que são enviados abaixo das linhas de cabeçalho. Em uma mensagem de resposta, o corpo da mensagem é o recurso que foi requisitado pelo cliente, ou ainda uma mensagem de erro, caso este recurso não seja possível. Já em uma mensagem de requisição, o corpo pode conter dados que serão enviados diretamente pelo usuário ou um arquivo que será enviado para o servidor. Quando uma mensagem HTTP tiver um corpo, poderão ser incluídos cabeçalhos de entidades que descrevem suas características, como por exemplo, o ''Content-Type'' que informa o tipo MIME dos dados no corpo da mensagem e o ''Content-Length'' que informa a quantidade de bytes que o corpo da mensagem contém. A tabela ao lado apresenta alguns tipos MIME.
 
=== Requisição ===
De acordo com Fielding,<ref>Fielding (1999, p. 24)</ref> uma mensagem de requisição do cliente é composta pelos seguintes campos: uma linha inicial (''Request-Line''); linhas de cabeçalhos (''Request-header''); uma linha em branco obrigatória e um corpo de mensagem opcional. A linha inicial de uma requisição é composta por três partes separadas por espaços: o método (''Method''), a identificação do URI (''Request-URI'') e a versão do HTTP (''HTTP-Version'') utilizado.
 
Segundo Bastos & Ladeira,<ref>Bastos & Ladeira</ref> ''Request-URI'' é um ''identificador uniforme de recurso'' (Uniform Resource Identifier) que identifica sobre qual recurso será aplicada a requisição. No protocolo HTTP, o tipo de URI utilizado é chamado de URL (Uniform Resource Locator), composto pela identificação do protocolo, pelo endereço do computador servidor e pelo documento requisitado.<ref>cf. Embratel, 2002</ref>
 
== Métodos de solicitação ==
O protocolo HTTP define oito métodos (GET, HEAD, POST, PUT, DELETE, TRACE, OPTIONS e CONNECT) que indicam a ação a ser realizada no recurso especificado. Conforme Bastos e Ladeiras,<ref>Bastos & Ladeiras (2001)</ref> o método determina o que o servidor deve fazer com o URL fornecido no momento da requisição de um recurso. Um [[servidor HTTP]] deve implementar ao menos os métodos GET e HEAD. Os métodos GET e POST são os que aparecem mais comumente durante o desenvolvimento web.
 
Uma '''solicitação HTTP''', ou ''HTTP Request'' é uma maneira do [[Navegador (informática)|navegador]] mostrar uma [[site|página da internet]] utilizando um dos oito métodos de solicitação do protocolo HTTP.<ref name="HTTP Request">{{citar web|url=http://www.portais.ws/?page=art_det&ida=1354|titulo=O que é um 'HTTP request'?|publicado=www.portais.ws|acessodata=15-03-2011}}</ref>
 
Além de solicitar um determinado arquivo, envia várias informação para o servidor, sendo elas: o seu [[IP]], a versão do navegador que está usando, que página utilizou para pedir a ''HTTP Request'' e a idioma que você usa, entre outros.<ref name="HTTP Request" />
 
=== GET ===
O método GET requisita uma representação do recurso especificado. Requisições usando GET devem apenas [[recuperar dados]] e não devem ter qualquer outro efeito. (Isto também é verdade para alguns outros métodos HTTP.) O [[W3C]] publicou princípios de orientações sobre esta distinção, "O projeto de [[Aplicação web|aplicações web]] devem ser informados pelos princípios acima, mas também por limitações relevantes."
 
Abaixo segue um exemplo de uma comunicação entre um cliente e um servidor HTTP. O servidor possui a URL <code>www.exemplo.com</code>, porta 80.
 
O ''pedido do cliente'' (seguido por uma linha em branco, de maneira que o pedido termina com um ''[[newline]]'' duplo, cada um composto por um ''[[carriage return]]'' seguido de um ''[[Line Feed]]''):
GET /index.html HTTP/1.1
Host: www.exemplo.com
 
O cabeçalho <code>Host</code> reconhece vários diferentes nomes [[Domain Name System|DNS]] que tenham o mesmo [[IP]].
 
A ''resposta do servidor'' (seguida por uma linha em branco e o texto da página solicitada):
HTTP/1.1 200 OK
Date: Mon, 23&nbsp;May 2005&nbsp;22:38:34 GMT
Server: Apache/1.3.27 (Unix)  (Red-Hat/Linux)
Last-Modified: Wed, 08 Jan 2003 23:11:55 GMT
Etag: "3f80f-1b6-3e1cb03b"
Accept-Ranges: bytes
Content-Length: 438
Connection: close
Content-Type: text/html; charset=UTF-8
 
=== HEAD ===
Variação do <code>GET</code> em que o recurso não é retornado. É usado para obter [[metainformação|metainformações]] por meio do cabeçalho da resposta, sem ter que recuperar todo o conteúdo.
 
=== POST ===
{{Artigo principal|POST (HTTP)}}
Envia dados para serem processados (por exemplo, dados de um formulário HTML) para o recurso especificado. Os dados são incluídos no corpo do comando.  Sua utilização em uma requisição ocorre quando é necessário enviar dados ao servidor para serem processados, geralmente por um programa ''script'' identificado no ''Request-URI''. Uma requisição por meio desse método sempre requer que as informações submetidas sejam incluídas no corpo da mensagem e formatadas como uma ''query string'', além de conter cabeçalhos adicionais especificando seu tamanho (<code>Content-Length</code>) e seu formato (<code>Content-Type</code>). Por isso, esse método oferece uma maior segurança em relação aos dados transferidos, ao contrário do método <code>GET</code> que os dados são anexados a URL, ficando visíveis ao usuário.<ref>Herrmann, 1997</ref> Por exemplo:
 
  POST /index.html HTTP/1.0
  Accept: text/html
  If-modified-since: Sat, 29 Oct 1999 19:43:31 GMT
  Content-Type: application/x-www-form-urlencoded
  Content-Length: 41
 
  Nome=NomePessoa&Idade=99&Curso=Computacao
 
=== PUT ===
O método PUT envia os dados de forma semelhante ao POST, através do corpo do HTTP a diferença entre os 2 métodos é semântica. Por exemplo:
 
Caso você necessite atualizar os dados de um usuário, utilizando o método PUT você pode os atualizar diversas vezes, pois o PUT vai sobrescrever os dados com isso ficará somente com um único registro atualizado.
 
Se você executasse este mesmo procedimento utilizando o método POST, você criaria diversos registros para cada requisição realizada.
 
=== DELETE ===
Exclui o recurso.
 
=== TRACE ===
Ecoa o pedido, de maneira que o cliente possa saber o que os servidores intermediários estão mudando em seu pedido.
 
=== OPTIONS ===
Recupera os métodos HTTP que o servidor aceita.
 
=== CONNECT ===
Serve para uso com um ''proxy'' que possa se tornar um túnel [[SSL]] e TLS (um túnel pode ser usado, por exemplo, para criar uma conexão segura).
 
== Códigos de estado ==
:''Ver também: [[Lista de códigos de status HTTP]]''
 
Do HTTP/1.0 em diante, a primeira linha da resposta HTTP é chamada ''linha de estado'' e inclui um ''código de estado'' numérico (como "[[HTTP 404|404]]") e uma ''frase de razão'' textual (como "Not Found" - Não Encontrado). A maneira que o [[agente de usuário]] manipula a resposta depende primeiramente do código e secundariamente nos [[cabeçalhos de resposta]]. Códigos de estado personalizados podem ser usados, uma vez que, se o agente de usuário encontrar um código que ele não reconheça, ele pode usar o primeiro dígito do código para determinar a classe geral da resposta.
 
Da mesma forma, as ''frases de razão'' padrões são apenas recomendações e podem ser substituídas com "equivalentes locais" a critério do desenvolvedor web. Se o código de estado indicou um problema, o agente de usuário pode mostrar a ''frase de razão'' para o usuário, para que sejam fornecidas informações adicionais sobre a natureza do problema. O padrão também permite que o agente de usuário tente interpretar a ''frase de razão'', apesar disto poder ser imprudente uma vez que o padrão especifica explicitamente que os códigos de estado são legíveis por máquina e as ''frases de razão'' são legíveis por homens.
 
== Conexões persistentes ==
{{Artigo principal|Conexão persistente HTTP}}
 
No HTTP/0.9 e 1.0, a conexão é fechada após um único par de requisição/resposta. No HTTP/1.1 um mecanismo de persistência de vida (keep-alive) foi introduzido, onde uma conexão pode ser reutilizada para mais de uma requisição. Tais ''conexões persistentes'' reduzem a [[latência]] de requisição perceptível, pois o cliente não precisa renegociar a conexão TCP após a primeira requisição ter sido enviada. Outro efeito colateral positivo é que em geral a conexão se torna mais rápida com o tempo devido ao mecanismo de [[início-lento]] do TCP.
 
A versão 1.1 do protocolo também faz melhoras na otimização de comprimento de banda para o HTTP/1.0. Por exemplo, o HTTP/1.1 introduziu a [[codificação de transferência em partes]] para permitir que o conteúdo em conexões persistentes sejam transmitidos em vez de armazenados temporariamente para posterior transmissão. O [[pipelining HTTP]] reduz ainda mais o tempo de atraso, permitindo que os clientes enviem várias requisições antes de esperar por cada resposta. Outra melhoria para o protocolo foi o [[byte serving]], onde um servidor transmite apenas a porção de um recurso solicitado explicitamente por um cliente.
 
== Estado de sessão HTTP ==
O HTTP é um [[protocolo sem estado]]. Um protocolo sem estado não exige que o servidor HTTP retenha informações ou estado sobre cada usuário para a duração de várias solicitações. Entretanto, algumas [[Aplicação web|aplicações web]] implementam estado ou [[Sessão (ciência da computação)|sessões do lado servidor]] usando um ou mais de um dos métodos a seguir:
* [[Variável oculta|Variáveis ocultas]] dentro de [[Formulário (HTML)|formulários web]];
* [[Cookie (informática)|Cookies HTTP]];
* Parâmetros de [[query string]], por exemplo, /index.php?session_id=algum_código_único_de_sessão.
 
== Resposta ==
Para Fielding,<ref>Fielding et al (1999, p. 26)</ref> uma mensagem de resposta do servidor é composta pelos seguintes campos: uma linha inicial (''Status-Line''); linhas de cabeçalhos (''Responseheader''); uma linha em branco obrigatória e um corpo de mensagem opcional. A linha inicial de uma resposta, chamada de linha de status, possui por sua vez três partes separadas por espaços: a versão do protocolo HTTP (''HTTP-Version''), um código de status (''Status-Code'') da resposta, que fornece o resultado da requisição, e uma frase de justificativa (''Reason-Phrase'') que descreve o código do status.
 
=== Códigos de retorno ===
A linha inicial de uma resposta HTTP indica ao cliente se sua requisição foi bem sucedida ou não.<ref>cf. Herrman, 1997, p. 53</ref> Essa situação é fornecida através de um código de retorno (''Status-Code'') e uma frase explicativa (''Reason-Phrase''). De acordo com Fielding,<ref>Fielding et al (1999, p. 37)</ref> o código de status é formado por três dígitos e o primeiro dígito representa a classe que pertence classificada em cinco tipos:
 
* ''1xx'': ''Informational'' (Informação) – utilizada para enviar informações para o cliente de que sua requisição foi recebida e está sendo processada;
* ''2xx'': ''Success'' (Sucesso) – indica que a requisição do cliente foi bem sucedida;
* ''3xx'': ''Redirection'' (Redirecionamento) – informa a ação adicional que deve ser tomada para completar a requisição;
* ''4xx'': ''Client Error'' (Erro no cliente) – avisa que o cliente fez uma requisição que não pode ser atendida;
* ''5xx'': ''Server Error'' (Erro no servidor) – ocorreu um erro no servidor ao cumprir uma requisição válida.


O protocolo HTTP define somente alguns códigos em cada classe descritos na RFC 2616, mas cada servidor pode definir seus próprios códigos.
O protocolo HTTP define somente alguns códigos em cada classe descritos na RFC 2616, mas cada servidor pode definir seus próprios códigos.


==1.4 Conexões==
=== Conexões ===
Segundo Hirata,<ref>Hirata, 1999</ref> o HTTP/1.0 é um protocolo sem estado. Isto significa que as conexões entre um cliente e um servidor são encerradas após o envio de cada requisição ou resposta. Cada vez que uma conexão é estabelecida ou encerrada, é consumida uma grande quantidade de tempo da CPU, de largura de banda e de memória.
 
Na maioria das vezes, para se obter o resultado esperado, é necessário realizar mais de uma solicitação de recursos através de várias conexões. Por exemplo, no caso de uma página Web, que consiste de diversos arquivos (.html, .gif, .css, etc.) é preciso que sejam feitas várias requisições para compor a página, uma conexão não-persistente. O ideal seria que apenas uma conexão fosse utilizada para os pedidos e as respostas HTTP, diminuindo, assim, a [[overhead|sobrecarga]] ocasionada pelas conexões, uma conexão persistente.
 
A conexão persistente, implementada como conexão padrão no protocolo HTTP/1.1, possibilita que uma conexão seja estabelecida para enviar várias requisições em seqüência sem a necessidade de esperar por cada resposta, no qual serão recebidas na mesma ordem em que as solicitações foram enviadas, um processo chamado de ''pipelining''.<ref>cf. Fielding et al, 1999, p. 30</ref> Pode também dar-se o caso de ser estabelecida uma conexão sem ''pipelining'', em que o cliente só faz nova requisição quando o servidor lhe envia a resposta, ou seja, o servidor fica inactivo até o objecto (.html, .gif, .css, etc) atingir o seu destino no cliente.
 
Se uma requisição incluir o cabeçalho <code>Connection: close</code>, a conexão será encerrada após o envio da resposta correspondente. Utiliza-se este cabeçalho quando não há suporte a conexões persistentes, quando for a última requisição a ser enviada nesta conexão, ou ainda, sempre que quiser encerrar a conexão mesmo que nem todas as requisições tenham sido completadas. Além disso, o servidor pode fechar uma conexão se estiver ociosa por um determinado período de tempo.
 
=== Outros protocolos ===
Existem outros tipos de protocolos como o [[FTP]] (File Transfer Protocol, ou Protocolo de Transferência de Arquivos), usado para envio de arquivos do computador para um servidor na Web, o [[SMTP]] (Simple Mail Transfer Protocol, ou Protocolo de Transferência de Correio Simples), protocolo usado para [[correio eletrônico]], entre outros protocolos.


Segundo Hirata ( p5,. HIRATA, Renato. Desempenho em Servidores Web de Grande Porte. 1999. Proposta de Tese de  Mestrado  –  Universidade Estadual de Campinas, São Paulo, 1999. Disponível em:
== Esquema de comunicação ==
http://www.ic.unicamp.br/~ra951407/PROPOSTA.DOC. Acesso em: 25 fev. 2002), o HTTP/1.0 é um protocolo stateless. Isto significa que as conexões entre um cliente e um servidor são encerradas após o envio de cada requisição ou resposta. Cada vez que uma conexão é estabelecida ou encerrada, é consumida uma grande quantidade de tempo da CPU, de largura de banda e de memória.
Pedido básico de HTTP cliente-servidor:
Na maioria das vezes, para se obter o resultado esperado, é necessário realizar mais de uma solicitação de recursos através de várias conexões. Por exemplo, no caso de uma página Web, que consiste de diversos arquivos (.html, .gif, .css, etc) é preciso que sejam feitas várias requisições para compor a página. O ideal seria que apenas uma conexão fosse utilizada para os pedidos e as respostas HTTP, diminuindo, assim, o overhead ocasionado pelas conexões. Este tipo de conexão é chamado de conexão persistente (Persistent Connection). A Figura 13 ilustra uma comparação entre a conexão stateless e a conexão persistente.
[[Imagem:httpfoto.jpg]]


A conexão persistente, implementada como conexão padrão no protocolo HTTP/1.1, possibilita que uma conexão seja estabelecida para enviar várias requisições em seqüência sem a necessidade de esperar por cada resposta, no qual serão recebidas na mesma ordem em que as solicitações foram enviadas, este processo é chamado de pipelining (cf. Fielding et al, 1999, p. 30).
GET <ficheiro> HTTP/1.1
Se uma requisição incluir o cabeçalho Connection: close, a conexão será encerrada após o envio da resposta correspondente. Utiliza-se este cabeçalho quando não há suporte a conexões persistentes, quando for a última requisição a ser enviada nesta conexão, ou ainda, sempre que quiser encerrar a conexão mesmo que nem todas as requisições tenham sido completadas. Além disso, o servidor pode fechar uma conexão se estiver ociosa por um determinado período de tempo.
Host: <ip>
User-Agent: <Agente>
Connection: <tipo>


==1.5 Considerações finais==
O agente é quem faz a ligação ao servidor, normalmente um [[Navegador (informática)|navegador]]. O tipo indica como o servidor deve proceder com a conexão. É comumente utilizado para requisições persistentes.


De acordo com o que foi apresentado, o HTTP é um protocolo de uso genérico que pode ser usado para diversos tipos de tarefas, através da extensão dos seus métodos de requisição e resposta, códigos de erros e cabeçalhos. Desta forma, o protocolo HTTP é uma alternativa para a comunicação de aplicações distribuídas em applets Java na Internet, devido à utilização deste protocolo como forma de comunicação padrão entre servidores Web. Além disso, permite que estas aplicações sejam executadas sem a necessidade de utilizar uma arquitetura proprietária2.
Uma requisição completa pode exigir muitas informações. A requisição abaixo - utilizando o método POST - fora retirada do Mozilla Firefox v3.6b5 (pt-BR, para Windows):


==Os principais comandos do HTTP==
POST /diretorio/arquivo.html HTTP/1.1
Host: www.exemplo.com
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; pt-BR; rv:1.9.2b5) Gecko/20091204 Firefox/3.6b5
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: pt-br,pt;q=0.8,en-us;q=0.5,en;q=0.3
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-alive: 115
Cookie: nome=valor; nome2=valor2
Connection: keep-alive
Content-Length: 28


Os principais comandos são:Get,Post,Trace,Option e Help.
usuario=exemplo&senha=123456
A sua sintaxe(estrutura)é: <comando> <documento> HTTP/1.x.Para abrir um canal de comunicação com o serviço HTTP, podemos usar o telnet.Uma diferença entre usar o telnet para estabelecer a comunicação e usar o navegador é que o navegador envia mais parâmetros nos comandos,para detalhar o tipo de conteúdo aceito,as configurações,etc.


==Esquema de comunicação HTTP==
== Ver também ==
usuário - cliente(browser,ou em português navegador) -GET /index.html HTTP/1.0 -Servidor
* [[HTTP/2]] - Revisão do HTTP baseada no SPDY
* [[HTTP/3]] - Revisão do HTTP baseada no QUIC
* [[HTTP referrer]]
* [[Hyper Text Transfer Protocol Secure|Hyper Text Transfer Protocol Secure (HTTPS)]]
* [[Lista de códigos de status HTTP]]
* [[QUIC]] – Protocolo de aplicação que usa o [[User Datagram Protocol|UDP]] no lugar do [[Transmission Control Protocol|TCP]]
* [[Representational State Transfer]] (REST)
* [[Sistema de Arquivos Interplanetário]]
* [[SPDY]] – Um aprimoramento do HTTP proposto pela [[Google]]
* [[Web cache]]
* [[WebSockets]]
* [[World Wide Web|World Wide Web (WWW)]]


==Bibliografia==
{{Referências|col=2}}
*[http://www.dca.fee.unicamp.br/cursos/PooJava/network/http.html Mais detalhes sobre o HTTP]
*[http://www.w3.org/Protocols/ para saber como anda o desenvolvimento do protocolo HTTP]


== Bibliografia ==
* {{citar web|url=http://www.rfc-editor.org/cgi-bin/rfcdoctype.pl?loc=RFC&letsgo=1945&type=ftp&file_format=txt|titulo=Hypertext Transfer Protocol -- HTTP/1.0|autor=T. Berners-Lee, R. Fielding, H. Frystyk|data=maio de 1996|lingua=inglês|acessodata=21 de junho de 2009|publicado=[[Internet Engineering Task Force]]|arquivourl=https://web.archive.org/web/20050505112439/http://www.rfc-editor.org/cgi-bin/rfcdoctype.pl?loc=RFC|arquivodata=2005-05-05|urlmorta=yes}}
* BASTOS, Leonara de Oliveira; LADEIRA, Adriane Cristina. Protocolo HTTP.<!-- melhorar esta referência -->
* cf. 46 HERRMANN, Eric. Aprenda em 1 semana programação CGI em Perl 5. Rio de Janeiro: Campus, 1997
* MACEDO, R. T. et al. Redes de computadores. 1. ed, 2018, Santa Maria, RS. p. 139.


{{esboço-informática}}
== Ligações externas ==
* {{link|en|2=https://www.w3.org/Protocols/|3=Desenvolvimento do protocolo HTTP}}
* {{link|pt-br|2=https://www.alura.com.br/artigos/desmistificando-o-protocolo-http-parte-1|3=Desmistificando o protocolo HTTP}}


[[Categoria:Acrónimo]]
{{Navegadores web}}
[[Categoria:Tecnologias WWW]]
[[Categoria:WWW]]


[[ar:HTTP]]
[[Categoria:HTTP]]
[[ca:Protocol de transferència d'hipertext]]
[[Categoria:Protocolos Internet]]
[[cs:HTTP]]
[[Categoria:Protocolos de camada de aplicação]]
[[da:HTTP]]
[[Categoria:Padrões abertos]]
[[de:Hypertext Transfer Protocol]]
[[Categoria:Navegadores web]]
[[en:HyperText Transfer Protocol]]
[[Categoria:Web]]
[[eo:Hiperteksto-Transiga Protokolo]]
[[Categoria:Normas W3C]]
[[es:Hypertext Transfer Protocol]]
[[et:Hypertext Transfer Protocol]]
[[fi:HTTP]]
[[fr:Hypertext Transfer Protocol]]
[[he:HTTP]]
[[hu:HTTP]]
[[id:HTTP]]
[[it:HTTP]]
[[ja:Hypertext Transfer Protocol]]
[[ko:HTTP]]
[[lt:HTTP]]
[[lv:HTTP]]
[[nl:Hypertext Transfer Protocol]]
[[nn:Hypertext Transfer Protocol]]
[[no:HTTP]]
[[pl:HTTP]]
[[ro:HTTP]]
[[ru:HTTP]]
[[sk:Hypertext Transfer Protocol]]
[[sl:HTTP]]
[[sv:HTTP]]
[[th:HyperText Transfer Protocol]]
[[tl:HTTP]]
[[tr:HTTP]]
[[zh:超文本传输协议]]

Edição atual tal como às 15h33min de 25 de agosto de 2022

Erro de script: Nenhum módulo desse tipo "sidebar". O Hypertext Transfer Protocol, sigla HTTP (em português Protocolo de Transferência de Hipertexto) é um protocolo de comunicação (na camada de aplicação segundo o Modelo OSI) utilizado para sistemas de informação de hipermídia, distribuídos e colaborativos.[1] Ele é a base para a comunicação de dados da World Wide Web.

Hipertexto é o texto estruturado que utiliza ligações lógicas (hiperlinks) entre nós contendo texto. O HTTP é o protocolo para a troca ou transferência de hipertexto.

Coordenado pela World Wide Web Consortium e a Internet Engineering Task Force, culminou na publicação de uma série de Requests for Comments; mais notavelmente o RFC 2616, de junho de 1999, que definiu o HTTP/1.1. Em Junho de 2014 foram publicados 6 RFC's para maior clareza do protocolo HTTP/1.1.[2] Em Março de 2015, foi divulgado o lançamento do HTTP/2. A atualização deixará o navegador com um tempo de resposta melhor e mais seguro. Ele também melhorará a navegação em smartphones.[3] Os trabalhos no HTTP/3 já começaram e suas versões beta estão em teste por grandes empresas.[4]

Para acedermos a outro documento a partir de uma palavra presente no documento actual podemos utilizar hiperligações (ou âncoras). Estes documentos se encontram no sítio com um endereço de página da Internet – e para acessá-los deve-se digitar o respectivo endereço, denominado URI (Universal Resource Identifier ou Identificador Universal de Recurso), que não deve ser confundido com URL (Universal Resource Locator ou Localizador Universal de Recurso), um tipo de URI que pode ser directamente localizado.

Visão técnica geral

O HTTP funciona como um protocolo de requisição-resposta no modelo computacional cliente-servidor. Um navegador web, por exemplo, pode ser o cliente e uma aplicação em um computador que hospeda um sítio da web pode ser o servidor. O cliente submete uma mensagem de requisição HTTP para o servidor. O servidor, que fornece os recursos, como arquivos HTML e outros conteúdos, ou realiza outras funções de interesse do cliente, retorna uma mensagem resposta para o cliente. A resposta contém informações de estado completas sobre a requisição e pode também conter o conteúdo solicitado no corpo de sua mensagem.

Um navegador web é um exemplo de agente de usuário (AU). Outros tipos de agentes de usuário incluem o software de indexação usado por provedores de consulta (web crawler), navegadores vocais, aplicações móveis e outros software que acessam, consomem ou exibem conteúdo web.

O HTTP é projetado para permitir intermediações de elementos de rede para melhorar ou habilitar comunicações entre clientes e servidores. Sites web de alto tráfego geralmente se beneficiam dos servidores de cache web que entregam conteúdo em nome de servidores de upstream para melhorar o tempo de resposta. Navegadores web armazenam os recursos web acessados anteriormente e reutilizam-nos quando possível para reduzir o tráfego de rede. Servidores proxy HTTP nas fronteiras de redes privadas podem facilitar a comunicação para o cliente sem um endereço globalmente roteável, transmitindo mensagens com servidores externos.

Basicamente, o HTTP define como clientes Web requisitam páginas Web aos servidores e como elas as transferem a clientes. Quando um usuário solicita uma página Web (acessa uma URL), o navegador envia ao servidor mensagens de requisição HTTP para os objetos da página. O servidor, por sua vez, recebe estas requisições e responde com mensagens de resposta HTTP que contém os objetos (...). O protocolo HTTP utiliza por padrão a porta 80 para comunicação (MACEDO et al., 2018).[5]

História

O HyperText Transfer Protocol é um protocolo de aplicação responsável pelo tratamento de pedidos e respostas entre cliente e servidor na World Wide Web. Ele surgiu da necessidade de distribuir informações pela Internet e para que essa distribuição fosse possível foi necessário criar uma forma padronizada de comunicação entre os clientes e os servidores da Web e entendida por todos os computadores ligados à Internet. Com isso, o protocolo HTTP passou a ser utilizado para a comunicação entre computadores na Internet e a especificar como seriam realizadas as transacções entre clientes e servidores, através do uso de regras básicas.

Este protocolo tem sido usado pela WWW desde 1990. A primeira versão de HTTP, chamada HTTP/0.9, era um protocolo simples para a transferência de dados no formato de texto ASCII pela Internet, através de um único método de requisição, chamado GET. A versão HTTP/1.0 foi desenvolvida entre 1992 e 1996 para suprir a necessidade de transferir não apenas texto. Com essa versão, o protocolo passou a transferir mensagens do tipo MIME44 (Multipurpose Internet Mail Extension) e foram implementados novos métodos de requisição, chamados POST e HEAD.

No HTTP/1.1, versão do protocolo descrito na RFC 2616,[6] foi desenvolvido um conjunto de implementações adicionais ao HTTP/1.0, como por exemplo: o uso de conexões persistentes; o uso de servidores proxy que permitem uma melhor organização da cache; novos métodos de requisições; entre outros. Afirma-se que o HTTP também é usado como um protocolo genérico para comunicação entre os agentes de utilizadores e proxies/gateways com outros protocolos, como o SMTP, NNTP, FTP, Gopher, e WAIS, permitindo o acesso a recursos disponíveis em aplicações diversas.[6]

O HTTP/2 foi publicado como RFC 7540 em maio de 2015.

Ano Versão do HTTP
1991 0.9
1996 1.0
1997 1.1
2015 2.0
2018 3.0

Sessão HTTP

Uma sessão HTTP é uma sequência de transações de rede de requisição-resposta. Um cliente HTTP inicia uma requisição estabelecendo uma conexão Transmission Control Protocol (TCP) para uma porta particular de um servidor (normalmente a porta 80. Veja Lista de portas dos protocolos TCP e UDP). Um servidor HTTP ouvindo naquela porta espera por uma mensagem de requisição de cliente. Recebendo a requisição, o servidor retorna uma linha de estado, como "HTTP/1.1 200 OK", e uma mensagem particular própria. O corpo desta mensagem normalmente é o recurso solicitado, apesar de uma mensagem de erro ou outra informação também poder ser retornada.

Cookies

Ver artigo principal: Cookie HTTP

O termo cookie é derivado do inglês que significa biscoito. Recebeu esse nome de uma antiga gíria usada pelos programadores que consistia em um programa que chamava um procedimento e recebia de volta algo que seria necessário apresentar novamente mais tarde para realizar algum trabalho. Foi criado pela Netscape para solucionar o problema do envio e solicitação de arquivos, que eram esquecidos pelo servidor e que poderiam ser usados por outros computadores com o mesmo IP conforme (TANEMBAUM, 2003), o que causava problemas, pois não se sabia na realidade se era ou não aquele usuário mesmo. Os cookies são arquivos ou strings e não são programas executáveis. Eles são tratados como dados pelo navegador, não existe nenhuma maneira dele ser usado como vírus, apesar de que podem ser explorados bugs no servidor e causar a ativação de um cookie como vírus, por um hacker. Basicamente ele é um grupo de dados trocados entre o servidor de páginas e o navegador colocado em um ficheiro criado no computador do usuário. Serve para manter a persistência das sessões HTTP. Ele funciona da seguinte forma: Um usuário solicita uma página da Web, nisso o servidor pode fornecer informações adicionais acompanhando a página solicitada. Essas informações podem incluir um cookie, um pequeno arquivo ou string (com quatro KB no máximo). Este cookie pode ter até 5 campos (figura abaixo): Domain, Path, Content, Expires, Secure. Domain informa de onde veio o cookie. O navegador confirma que os servidores estão enviando dados fieis a respeito de seu domínio. Cada domínio pode armazenar no máximo 20 cookies por cliente. O campo Path é um caminho na estrutura de diretórios do servidor que identifica as partes da árvore de arquivos do servidor que podem usar o cookie. Frequentemente, ele obtém o símbolo / (barra), que representa a árvore inteira. O campo Content utiliza a forma nome = valor, podendo o servidor definir da maneira que quiser tanto o valor quanto o nome, e é nele que fica armazenado o conteúdo do cookie. Expires é o campo que faz o cookie persistir, nele contém a data e o horário, e se ele estiver ausente o navegador descartara automaticamente após o termino da sessão. O último campo define se ele é seguro ou não.

Domain Path Content Expires Secure
toms-casino.com / CustomerlD=497793521 15 de outubro de 2002

17:00

Yes joes-store.com / Cart=1-00501;1-07031;2-13721 11 de outubro de 2002

14:22

No
aportal.com / Prefs=Stk:SUNW+ORCL;Spt:Jet

s

31 de dezembro de 2010

23:59

No
sneaky.com 31- / UserID=3627239101 12-12

23:59

No

Figura x: Alguns exemplos de cookie.↵Fonte: (TANEMBAUM, 2003).

O cookie é usado para identificar um usuário que configurou uma página web, para que na próxima vez que ele entrar ela esteja configurada do modo em que ele deixou. Pode ser usado também quando se faz a solicitação de armazenamento de senha, na vez posterior em que entrar no site, a sua senha será lembrada. É usado também em sites de compra, como e-commerce, armazenando os produtos que o cliente colocou no carrinho para que no final da compra não necessite fazer todo o processo novamente.

Funcionamento

Um sistema de comunicação em rede possui diversos protocolos que trabalham em conjunto para o fornecimento de serviços. Para que o protocolo HTTP consiga transferir seus dados pela Web, é necessário que os protocolos TCP e IP (Internet Protocol, Protocolo de Internet) tornem possível a conexão entre clientes e servidores através de sockets TCP/IP.

De acordo com Fielding,[7] o HTTP utiliza o modelo cliente-servidor, como a maioria dos protocolos de rede, baseando-se no paradigma de requisição e resposta. Um programa requisitante (cliente) estabelece uma conexão com um outro programa receptor (servidor) e envia-lhe uma requisição, contendo a URI, a versão do protocolo, uma mensagem MIME (padrão utilizado para codificar dados em formato de textos ASCII para serem transmitidos pela Internet) contendo os modificadores da requisição, informações sobre o cliente e, possivelmente, o conteúdo no corpo da mensagem.

O servidor responde com uma linha de status (status line) incluindo sua versão de protocolo e com os códigos de erro informando se a operação foi bem sucedida ou fracasso, seguido pelas informações do servidor, metainformações da entidade e possível conteúdo no corpo da mensagem. Após o envio da resposta pelo servidor, encerra-se a conexão estabelecida.

Mensagem HTTP

O protocolo HTTP faz a comunicação entre o cliente e o servidor por meio de mensagens. O cliente envia uma mensagem de requisição de um recurso e o servidor envia uma mensagem de resposta ao cliente com a solicitação. Segundo Foscarini,[8] os dois tipos de mensagens existentes no protocolo utilizam um formato genérico, definido na RFC 822, para a transferência de entidades.

Uma mensagem, tanto de requisição quanto de resposta, é composta, conforme definido na RFC 2616,[9] por uma linha inicial, nenhuma ou mais linhas de cabeçalhos, uma linha em branco obrigatória finalizando o cabeçalho e por fim o corpo da mensagem, opcional em determinados casos. Nessa sessão serão apresentados os campos que compõem uma mensagem mais detalhadamente; ou seja, o HTTP apresenta o sítio ou local onde está a página da Internet.

Cabeçalho da mensagem

O cabeçalho da mensagem (header) é utilizado para transmitir informações adicionais entre o cliente e o servidor. Ele é especificado imediatamente após a linha inicial da transação (método), tanto para a requisição do cliente quanto para a resposta do servidor, seguido de dois pontos (:) e um valor. Existem quatro tipos de cabeçalhos que poderão ser incluídos na mensagem os quais são: general-header, request-header, response-header e entity-header.[10]

Esses cabeçalhos são utilizados para enviar informações adicionais sobre a mensagem transmitida (general-header), a requisição e os clientes (request-header) que comunicam suas configurações e os formatos de documentos desejados como resposta.[11] Além disso, são utilizados pelo servidor ao retornar o recurso no qual foi requisitado pelo cliente, para transmitir informações que descrevem as configurações do servidor e do recurso identificado pelo URI de requisição, e que não pertence à linha de status (response-header). Na RFC 2616,[12] estão descritos todos os campos que pertencem a esses cabeçalhos.

Alguns tipos MIME[13]
Exemplo Descrição
text/plain Arquivo no formato texto (ASCII)
text/html Arquivo no formato HTML, utilizado
como padrão para documentos Web
Image/gif Imagem com o formato GIF
Image/jpeg Imagem com o formato JPEG
application/zip Arquivo compactado
application/json Arquivo no formato JSON
application/xml (ou text/xml) Arquivo no formato XML

Corpo da mensagem

Uma mensagem HTTP pode conter um corpo de dados que são enviados abaixo das linhas de cabeçalho. Em uma mensagem de resposta, o corpo da mensagem é o recurso que foi requisitado pelo cliente, ou ainda uma mensagem de erro, caso este recurso não seja possível. Já em uma mensagem de requisição, o corpo pode conter dados que serão enviados diretamente pelo usuário ou um arquivo que será enviado para o servidor. Quando uma mensagem HTTP tiver um corpo, poderão ser incluídos cabeçalhos de entidades que descrevem suas características, como por exemplo, o Content-Type que informa o tipo MIME dos dados no corpo da mensagem e o Content-Length que informa a quantidade de bytes que o corpo da mensagem contém. A tabela ao lado apresenta alguns tipos MIME.

Requisição

De acordo com Fielding,[14] uma mensagem de requisição do cliente é composta pelos seguintes campos: uma linha inicial (Request-Line); linhas de cabeçalhos (Request-header); uma linha em branco obrigatória e um corpo de mensagem opcional. A linha inicial de uma requisição é composta por três partes separadas por espaços: o método (Method), a identificação do URI (Request-URI) e a versão do HTTP (HTTP-Version) utilizado.

Segundo Bastos & Ladeira,[15] Request-URI é um identificador uniforme de recurso (Uniform Resource Identifier) que identifica sobre qual recurso será aplicada a requisição. No protocolo HTTP, o tipo de URI utilizado é chamado de URL (Uniform Resource Locator), composto pela identificação do protocolo, pelo endereço do computador servidor e pelo documento requisitado.[16]

Métodos de solicitação

O protocolo HTTP define oito métodos (GET, HEAD, POST, PUT, DELETE, TRACE, OPTIONS e CONNECT) que indicam a ação a ser realizada no recurso especificado. Conforme Bastos e Ladeiras,[17] o método determina o que o servidor deve fazer com o URL fornecido no momento da requisição de um recurso. Um servidor HTTP deve implementar ao menos os métodos GET e HEAD. Os métodos GET e POST são os que aparecem mais comumente durante o desenvolvimento web.

Uma solicitação HTTP, ou HTTP Request é uma maneira do navegador mostrar uma página da internet utilizando um dos oito métodos de solicitação do protocolo HTTP.[18]

Além de solicitar um determinado arquivo, envia várias informação para o servidor, sendo elas: o seu IP, a versão do navegador que está usando, que página utilizou para pedir a HTTP Request e a idioma que você usa, entre outros.[18]

GET

O método GET requisita uma representação do recurso especificado. Requisições usando GET devem apenas recuperar dados e não devem ter qualquer outro efeito. (Isto também é verdade para alguns outros métodos HTTP.) O W3C publicou princípios de orientações sobre esta distinção, "O projeto de aplicações web devem ser informados pelos princípios acima, mas também por limitações relevantes."

Abaixo segue um exemplo de uma comunicação entre um cliente e um servidor HTTP. O servidor possui a URL www.exemplo.com, porta 80.

O pedido do cliente (seguido por uma linha em branco, de maneira que o pedido termina com um newline duplo, cada um composto por um carriage return seguido de um Line Feed):

GET /index.html HTTP/1.1
Host: www.exemplo.com

O cabeçalho Host reconhece vários diferentes nomes DNS que tenham o mesmo IP.

A resposta do servidor (seguida por uma linha em branco e o texto da página solicitada):

HTTP/1.1 200 OK
Date: Mon, 23 May 2005 22:38:34 GMT
Server: Apache/1.3.27 (Unix)  (Red-Hat/Linux)
Last-Modified: Wed, 08 Jan 2003 23:11:55 GMT
Etag: "3f80f-1b6-3e1cb03b"
Accept-Ranges: bytes
Content-Length: 438
Connection: close
Content-Type: text/html; charset=UTF-8

HEAD

Variação do GET em que o recurso não é retornado. É usado para obter metainformações por meio do cabeçalho da resposta, sem ter que recuperar todo o conteúdo.

POST

Ver artigo principal: POST (HTTP)

Envia dados para serem processados (por exemplo, dados de um formulário HTML) para o recurso especificado. Os dados são incluídos no corpo do comando. Sua utilização em uma requisição ocorre quando é necessário enviar dados ao servidor para serem processados, geralmente por um programa script identificado no Request-URI. Uma requisição por meio desse método sempre requer que as informações submetidas sejam incluídas no corpo da mensagem e formatadas como uma query string, além de conter cabeçalhos adicionais especificando seu tamanho (Content-Length) e seu formato (Content-Type). Por isso, esse método oferece uma maior segurança em relação aos dados transferidos, ao contrário do método GET que os dados são anexados a URL, ficando visíveis ao usuário.[19] Por exemplo:

 POST /index.html HTTP/1.0
 Accept: text/html
 If-modified-since: Sat, 29 Oct 1999 19:43:31 GMT
 Content-Type: application/x-www-form-urlencoded
 Content-Length: 41
 Nome=NomePessoa&Idade=99&Curso=Computacao

PUT

O método PUT envia os dados de forma semelhante ao POST, através do corpo do HTTP a diferença entre os 2 métodos é semântica. Por exemplo:

Caso você necessite atualizar os dados de um usuário, utilizando o método PUT você pode os atualizar diversas vezes, pois o PUT vai sobrescrever os dados com isso ficará somente com um único registro atualizado.

Se você executasse este mesmo procedimento utilizando o método POST, você criaria diversos registros para cada requisição realizada.

DELETE

Exclui o recurso.

TRACE

Ecoa o pedido, de maneira que o cliente possa saber o que os servidores intermediários estão mudando em seu pedido.

OPTIONS

Recupera os métodos HTTP que o servidor aceita.

CONNECT

Serve para uso com um proxy que possa se tornar um túnel SSL e TLS (um túnel pode ser usado, por exemplo, para criar uma conexão segura).

Códigos de estado

Ver também: Lista de códigos de status HTTP

Do HTTP/1.0 em diante, a primeira linha da resposta HTTP é chamada linha de estado e inclui um código de estado numérico (como "404") e uma frase de razão textual (como "Not Found" - Não Encontrado). A maneira que o agente de usuário manipula a resposta depende primeiramente do código e secundariamente nos cabeçalhos de resposta. Códigos de estado personalizados podem ser usados, uma vez que, se o agente de usuário encontrar um código que ele não reconheça, ele pode usar o primeiro dígito do código para determinar a classe geral da resposta.

Da mesma forma, as frases de razão padrões são apenas recomendações e podem ser substituídas com "equivalentes locais" a critério do desenvolvedor web. Se o código de estado indicou um problema, o agente de usuário pode mostrar a frase de razão para o usuário, para que sejam fornecidas informações adicionais sobre a natureza do problema. O padrão também permite que o agente de usuário tente interpretar a frase de razão, apesar disto poder ser imprudente uma vez que o padrão especifica explicitamente que os códigos de estado são legíveis por máquina e as frases de razão são legíveis por homens.

Conexões persistentes

Ver artigo principal: Conexão persistente HTTP

No HTTP/0.9 e 1.0, a conexão é fechada após um único par de requisição/resposta. No HTTP/1.1 um mecanismo de persistência de vida (keep-alive) foi introduzido, onde uma conexão pode ser reutilizada para mais de uma requisição. Tais conexões persistentes reduzem a latência de requisição perceptível, pois o cliente não precisa renegociar a conexão TCP após a primeira requisição ter sido enviada. Outro efeito colateral positivo é que em geral a conexão se torna mais rápida com o tempo devido ao mecanismo de início-lento do TCP.

A versão 1.1 do protocolo também faz melhoras na otimização de comprimento de banda para o HTTP/1.0. Por exemplo, o HTTP/1.1 introduziu a codificação de transferência em partes para permitir que o conteúdo em conexões persistentes sejam transmitidos em vez de armazenados temporariamente para posterior transmissão. O pipelining HTTP reduz ainda mais o tempo de atraso, permitindo que os clientes enviem várias requisições antes de esperar por cada resposta. Outra melhoria para o protocolo foi o byte serving, onde um servidor transmite apenas a porção de um recurso solicitado explicitamente por um cliente.

Estado de sessão HTTP

O HTTP é um protocolo sem estado. Um protocolo sem estado não exige que o servidor HTTP retenha informações ou estado sobre cada usuário para a duração de várias solicitações. Entretanto, algumas aplicações web implementam estado ou sessões do lado servidor usando um ou mais de um dos métodos a seguir:

Resposta

Para Fielding,[20] uma mensagem de resposta do servidor é composta pelos seguintes campos: uma linha inicial (Status-Line); linhas de cabeçalhos (Responseheader); uma linha em branco obrigatória e um corpo de mensagem opcional. A linha inicial de uma resposta, chamada de linha de status, possui por sua vez três partes separadas por espaços: a versão do protocolo HTTP (HTTP-Version), um código de status (Status-Code) da resposta, que fornece o resultado da requisição, e uma frase de justificativa (Reason-Phrase) que descreve o código do status.

Códigos de retorno

A linha inicial de uma resposta HTTP indica ao cliente se sua requisição foi bem sucedida ou não.[21] Essa situação é fornecida através de um código de retorno (Status-Code) e uma frase explicativa (Reason-Phrase). De acordo com Fielding,[22] o código de status é formado por três dígitos e o primeiro dígito representa a classe que pertence classificada em cinco tipos:

  • 1xx: Informational (Informação) – utilizada para enviar informações para o cliente de que sua requisição foi recebida e está sendo processada;
  • 2xx: Success (Sucesso) – indica que a requisição do cliente foi bem sucedida;
  • 3xx: Redirection (Redirecionamento) – informa a ação adicional que deve ser tomada para completar a requisição;
  • 4xx: Client Error (Erro no cliente) – avisa que o cliente fez uma requisição que não pode ser atendida;
  • 5xx: Server Error (Erro no servidor) – ocorreu um erro no servidor ao cumprir uma requisição válida.

O protocolo HTTP define somente alguns códigos em cada classe descritos na RFC 2616, mas cada servidor pode definir seus próprios códigos.

Conexões

Segundo Hirata,[23] o HTTP/1.0 é um protocolo sem estado. Isto significa que as conexões entre um cliente e um servidor são encerradas após o envio de cada requisição ou resposta. Cada vez que uma conexão é estabelecida ou encerrada, é consumida uma grande quantidade de tempo da CPU, de largura de banda e de memória.

Na maioria das vezes, para se obter o resultado esperado, é necessário realizar mais de uma solicitação de recursos através de várias conexões. Por exemplo, no caso de uma página Web, que consiste de diversos arquivos (.html, .gif, .css, etc.) é preciso que sejam feitas várias requisições para compor a página, uma conexão não-persistente. O ideal seria que apenas uma conexão fosse utilizada para os pedidos e as respostas HTTP, diminuindo, assim, a sobrecarga ocasionada pelas conexões, uma conexão persistente.

A conexão persistente, implementada como conexão padrão no protocolo HTTP/1.1, possibilita que uma conexão seja estabelecida para enviar várias requisições em seqüência sem a necessidade de esperar por cada resposta, no qual serão recebidas na mesma ordem em que as solicitações foram enviadas, um processo chamado de pipelining.[24] Pode também dar-se o caso de ser estabelecida uma conexão sem pipelining, em que o cliente só faz nova requisição quando o servidor lhe envia a resposta, ou seja, o servidor fica inactivo até o objecto (.html, .gif, .css, etc) atingir o seu destino no cliente.

Se uma requisição incluir o cabeçalho Connection: close, a conexão será encerrada após o envio da resposta correspondente. Utiliza-se este cabeçalho quando não há suporte a conexões persistentes, quando for a última requisição a ser enviada nesta conexão, ou ainda, sempre que quiser encerrar a conexão mesmo que nem todas as requisições tenham sido completadas. Além disso, o servidor pode fechar uma conexão se estiver ociosa por um determinado período de tempo.

Outros protocolos

Existem outros tipos de protocolos como o FTP (File Transfer Protocol, ou Protocolo de Transferência de Arquivos), usado para envio de arquivos do computador para um servidor na Web, o SMTP (Simple Mail Transfer Protocol, ou Protocolo de Transferência de Correio Simples), protocolo usado para correio eletrônico, entre outros protocolos.

Esquema de comunicação

Pedido básico de HTTP cliente-servidor:

GET <ficheiro> HTTP/1.1
Host: <ip>
User-Agent: <Agente>
Connection: <tipo>

O agente é quem faz a ligação ao servidor, normalmente um navegador. O tipo indica como o servidor deve proceder com a conexão. É comumente utilizado para requisições persistentes.

Uma requisição completa pode exigir muitas informações. A requisição abaixo - utilizando o método POST - fora retirada do Mozilla Firefox v3.6b5 (pt-BR, para Windows):

POST /diretorio/arquivo.html HTTP/1.1
Host: www.exemplo.com
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 6.1; pt-BR; rv:1.9.2b5) Gecko/20091204 Firefox/3.6b5
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: pt-br,pt;q=0.8,en-us;q=0.5,en;q=0.3
Accept-Encoding: gzip,deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Keep-alive: 115
Cookie: nome=valor; nome2=valor2
Connection: keep-alive
Content-Length: 28
usuario=exemplo&senha=123456

Ver também

Referências

  1. T. Berners-Lee et all, 1996
  2. Mark Nottingham (7 de Junho de 2014). «RFC2016 está morto» (em inglês). Mark Nottingham. Consultado em 13 de junho de 2015 
  3. «HTTP/2: Internet mais rápida» 
  4. «Hypertext Transfer Protocol Version 3 (HTTP/3)» 
  5. Macedo, Ricardo, Tombesi (2018). REDES DE COMPUTADORES. Santa Maria: [s.n.] p. 139 
  6. 6,0 6,1 Fielding et al 1999, p. 7
  7. Fielding et al (1999, p. 10)
  8. Foscarini (2001, p. 13)
  9. Fielding et al, 1999, p. 21
  10. cf. Fielding et al, 1999, p. 21
  11. cf. Bastos & Ladeira, 2001
  12. cf. Fielding et al, 1999
  13. Fielding et al, 1999
  14. Fielding (1999, p. 24)
  15. Bastos & Ladeira
  16. cf. Embratel, 2002
  17. Bastos & Ladeiras (2001)
  18. 18,0 18,1 «O que é um 'HTTP request'?». www.portais.ws. Consultado em 15 de março de 2011 
  19. Herrmann, 1997
  20. Fielding et al (1999, p. 26)
  21. cf. Herrman, 1997, p. 53
  22. Fielding et al (1999, p. 37)
  23. Hirata, 1999
  24. cf. Fielding et al, 1999, p. 30

Bibliografia

  • T. Berners-Lee, R. Fielding, H. Frystyk (maio de 1996). «Hypertext Transfer Protocol -- HTTP/1.0» (em inglês). Internet Engineering Task Force. Consultado em 21 de junho de 2009. Arquivado do original em 5 de maio de 2005 
  • BASTOS, Leonara de Oliveira; LADEIRA, Adriane Cristina. Protocolo HTTP.
  • cf. 46 HERRMANN, Eric. Aprenda em 1 semana programação CGI em Perl 5. Rio de Janeiro: Campus, 1997
  • MACEDO, R. T. et al. Redes de computadores. 1. ed, 2018, Santa Maria, RS. p. 139.

Ligações externas

Predefinição:Navbox with collapsible groups

talvez você goste