Cabeçalhos HTTP
Os cabeçalhos HTTP permitem que o cliente e o servidor passem informações adicionais com a solicitação ou a resposta HTTP. Um cabeçalho de solicitação é composto por seu nome case-insensitive (não diferencia letras maiúsculas e minúsculas), seguido por dois pontos ':' e pelo seu valor (sem quebras de linha). Espaços em branco antes do valor serão ignorados.
Cabeçalhos proprietários personalizados podem ser adicionados usando o prefixo 'X-', mas essa convenção foi descontinuada em Junho de 2012, devido aos inconvenientes que causou quando os campos não-padronizados tornaram-se padronizados na RFC 6648; outros estão listados em um registro IANA, cujo o conteúdo original foi definido na RFC 4229. O IANA também mantém o registro das propostas de novas mensagens de cabeçalhos HTTP.
Cabeçalhos podem ser classificados de acordo com os seus contextos:
- Cabeçalho genérico: Cabeçalhos que podem ser usados tanto em solicitações quanto em respostas, porém sem relação com os dados eventualmente transmitidos no corpo da mensagem.
- Cabeçalho de solicitação: Cabeçalhos contendo mais informação sobre o recurso a ser obtido ou sobre o próprio cliente.
- Cabeçalho de resposta: Cabeçalhos contendo informação adicional sobre a solicitação, como a sua localização ou sobre o servidor.
- Cabeçalho de entidade: Cabeçalhos contendo mais informação sobre o conteúdo da entidade, como o tamanho do conteúdo ou o seu MIME-type.
Cabeçalhos também podem ser classificados de acordo com a forma que são manipulados por proxies.
- End-to-end headers
-
Esses cabeçalhos devem ser transmitidos para o destinatário final da mensagem; isso é, o servidor em caso de solicitação ou o cliente caso resposta. Proxies intermediários devem reenviar cabeçalhos de end-to-end sem alterações e caches devem armazená-los.
- Hop-by-hop headers
-
Esses cabeçalhos são significativos apenas para uma única conexão a nível de transporte e não devem ser reenviados por proxies ou armazenados em cache. Tais cabeçalhos são:
Connection
,Keep-Alive
,Proxy-Authenticate
,Proxy-Authorization
,TE
,Trailer
,Transfer-Encoding
andUpgrade
. Observe que apenas cabeçalhos hop-by-hop podem ser definidos utilizando o cabeçalho genéricoConnection
.
A lista a seguir resume os cabeçalhos HTTP pela categoria de uso. Para uma lista alfabética, utilize o menu à esquerda.
Autenticação
WWW-Authenticate
-
Define o método de autenticação que deve ser utilizado para conseguir acesso ao recurso.
-
Contém as credenciais para autenticar um User-Agent com o servidor.
Proxy-Authenticate
-
Define o método de autenticação que deve ser utilizado para conseguir acesso ao recurso por trás de um servidor Proxy.
-
Contém as credenciais para autenticar um User-Agent com o servidor Proxy.
Caching
Age
-
O tempo em segundos em que o objeto esteve em um cache de proxy.
Cache-Control
-
Especifica diretivas para mecanismos de cache em requisições e respostas.
Expires
-
A data/hora depois que a resposta é considerada obsoleta.
Pragma
-
Cabeçalho específico da implementação que pode ter varios efeitos em qualquer lugar ao longo da sequência de requisição-resposta. Usado para compatibilidade de versões anteriores com caches HTTP/1.0 onde o header Cache-Control ainda não está presente.
Warning
-
Um campo de alerta geral contendo informações sobre possíveis problemas.
Client hints
O recurso HTTP Client hints ainda está em desenvolvimento. A documentação está disponível no site do HTTP working group.
Accept-CH
Experimental-
Os servidores podem dar suporte para o Client hints usando o campo de cabeçalho Accept-CH ou um elemento HTML <meta> equivalente com atributo http-equiv ([HTML5]).
Accept-CH-Lifetime
Experimental-
Os servidores podem solicitar ao cliente que lembre-se do conjunto de Client hints que o servidor dá suporte por um período de tempo especificado, para permitir a entrega de Client hints em solicitações seguidas ao servidor de origem([RFC6454]).
Content-DPR
Experimental-
Um número que indica a proporção entre pixels físicos sobre pixels CSS da resposta de imagem selecionada.
DPR
Experimental-
Um número que indica o Device Pixel Ratio (DPR) atual do cliente, que é a proporção dos pixels físicos sobre os pixels CSS (Seção 5.2 de [CSSVAL]) do viewport do layout (Seção 9.1.1 do [CSS2]) no dispositivo.
Device-Memory
Experimental-
Tecnicamente uma parte da API de Memória do Dispositivo (Device Memory API), este cabeçalho representa uma quantidade aproximada de RAM que o cliente possui.
Save-Data
Experimental-
Um boleano que indica a preferência do agente do usuário pelo uso reduzido de dados.
Viewport-Width
Experimental-
Um número que indica a largura em pixels do viewport do layout em pixels CSS. O valor em pixels disponibilizado é um número arredondado do menor inteiro seguinte. (i.e. valor ceiling).
Se
Viewport-Width
ocorrer em uma mensagem mais de uma vez, o último valor irá sobrescrever todas as ocorrências anteriores. Width
Experimental-
O campo
Width
no cabeçalho da requisição é um número que indica a largura desejada do recurso em pixels físicos (i.e. tamanho intrínseco da imagem). O valor do pixel provido é um número arredondado para o menor inteiro seguinte.Se a largura do recurso desejada não for conhecida no momento da solicitação ou o recurso não tiver uma largura de exibição, o campo
Width
poderá ser omitido do cabeçalho. SeWidth
ocorrer em uma mensagem mais de uma vez, o último valor irá sobrescrever todas as ocorrências anteriores.
Condicionais
Last-Modified
-
É um validador, a última data de modificação de um recurso, usado para comparar várias versões de um mesmo recurso. É menos preciso que o
ETag
, mas é mais fácil calcular em alguns ambientes. Requisições condicionais usandoIf-Modified-Since
eIf-Unmodified-Since
usam esse valor para modificar o comportamento da requisição. ETag
-
É um validador, uma string única identificando a versão do recurso. Requisições condicionais usando
If-Match
eIf-None-Match
usam esse valor para modificar o comportamento da requisição. If-Match
-
Faz a requisição condicional e aplica o método apenas se o recurso armazenado corresponder a uma das ETags fornecidas.
If-None-Match
-
Faz a requisição condicional e aplica o método apenas se o recurso armazenado não corresponder a nenhuma das ETags fornecidas. É usado para atualizar caches ( para requisições seguras), ou para prevenir o upload de um novo recurso quando este já existe.
If-Modified-Since
-
Faz a requisição condicional e espera a entidade ser transmitida somente se tiver sido modificada após a data especificada. É usado para transmitir dados somente se o cache estiver desatualizado.
If-Unmodified-Since
-
Faz a requisição condicional e espera a entidade ser transmitida somente se não tiver sido modificada após a data especificada. É usado para garantir a coerência de um novo fragmento de um intervalo específico com os anteriores, ou para implementar um Sistema de Controle de concorrência otimista ao modificar os documentos existentes.
Gerenciamento de Conexão
Connection
-
Controla se uma conexão de rede continua ou não aberta após o término da transação atual.
Keep-Alive
-
Controla por quanto tempo uma conexão persistente deve permanecer aberta.
Negociação de conteúdo
Accept
-
Informa ao servidor sobre os tipos de dados que podem ser enviados de volta. Isto é MIME-type.
Accept-Charset
-
Informa ao servidor sobre qual conjunto de caracter o cliente é capaz de entender.
Accept-Encoding
-
Informa ao servidor sobre o algoritmo de codificação, geralmente um algoritmo de compressão, isto pode ser usado no recurso enviado de volta.
Accept-Language
-
Informa ao servidor sobre a linguagem que é esperada que o servidor envie de volta. Esta é uma dica e não está necessariamente sob controle total do usuário: o servidor deve sempre prestar atenção para não sobrepor uma escolha explícita do usuário (como selecionar uma linguagem em uma lista suspensa).
Controles
Expect
-
Indica expectativas que precisam ser atendidas pelo servidor para lidar adequadamente com a solicitação.
Max-Forwards
-
...
Cookies
-
Contém cookies HTTP armazenados previamente enviados pelo servidor com o cabeçalho
Set-Cookie
. -
Envia cookies do servidor para o agente de usuário.
-
Contém um cookie HTTP enviado anteriormente pelo servidor com o cabeçalho
Set-Cookie2
, mas se tornou obsoleto pela especificação. UseCookie
em vez disso. -
Envia cookies do servidor para o agente-usuário, mas se tornou obsoleto pela especificação. Use
Set-Cookie
em vez disso.
CORS
Access-Control-Allow-Origin
-
Indica se a resposta pode ser compartilhada.
Access-Control-Allow-Credentials
-
Indica se a resposta a requisição pode ou não ser exposta quando a flag de crendenciais é verdadeira.
Access-Control-Allow-Headers
-
Usado na resposta para uma solicitação de comprovação (preflight request) para indicar quais cabeçalhos HTTP podem ser usados ao fazer a solicitação real.
Access-Control-Allow-Methods
-
Especifica o método, ou métodos, permitido ao acessar o recurso em resposta à solicitação de comprovação (preflight request).
Access-Control-Expose-Headers
-
Indica quais cabeçalhos podem ser expostos como parte da resposta listando seus nomes.
Access-Control-Max-Age
-
Indica por quanto tempo os resultados de uma solicitação de comprovação (preflight request) podem ser armazenados em cache.
Access-Control-Request-Headers
-
Utilizado ao emitr uma solicitação de comprovação (preflight request) para informar ao servidor quais cabeçalhos HTTP serão usados quando a solicitação real for realizada.
Access-Control-Request-Method
-
Utilizado ao emitir uma solicitação de comprovação (preflight request) para informar ao servidor qual método HTTP será usado quando a solicitação real for realizada.
Origin
-
Inddica de onde uma busca se origina.
Timing-Allow-Origin
-
Especifica as origens que tem permissão para ver valores de atributos recuperados por meio de recursos da API de Tempo de Recurso (Resource Timing API) que, de outra forma, seriam relatados como zero devido a restrições de origem cruzada (cross-origin restrictions).
Do Not Track
Downloads
Content-Disposition
-
Indica se o recurso transmitido deve ser mostrado em linha (inline - comportamento padrão sem o cabeçalho), ou se deve apresentar uma caixa de diálogo "Salvar como".
Informações do corpo da mensagem
Content-Length
-
Indica o tamanho do corpo da mensagem, em decimal, enviado ao destinatário
Content-Type
-
Indica o tipo de mídia do recurso.
Content-Encoding
-
Usado para especificar o algoritmo de compressão.
Content-Language
-
Descreve a linguagem destinada ao público, para permitir que um usuário se diferencie de acordo com o idioma preferido dele.
Content-Location
-
Indica um local alternativo para os dados retornados.
Roteamento de mensagens (Proxies)
Forwarded
-
Contém informações do lado do cliente dos servidores proxy que é alterado ou perdido quando um proxy é envolvido no caminho de uma solicitação.
X-Forwarded-For
Non-standard-
Identifica os endereços de IP de origem de um cliente que se conecta a um servidor web por meio de um proxy HTTP ou balanceador de carga.
X-Forwarded-Host
Non-standard-
Identifica o host original que um cliente usou para se conectar ao proxy ou balanceador de carga.
X-Forwarded-Proto
Non-standard-
Identifica o protocolo (HTTP ou HTTPS) que um cliente usou para se conectar ao seu proxy ou balanceador de carga.
Via
-
Adicionado por proxies, ambos proxies de encaminhamento (forward) e reverso (reverse), e pode aparecer nos cabeçalhos de solicitação e de resposta.
Redirecionamentos
Location
-
Indica a URL para redirecionar uma página.
Contexto da requisição
From
-
Contém um endereço de e-mail da internet para um usuário humano que controla o agente do usuário solicitante.
Host
-
Especifica o nome de domínio do servidor (para hospedagem virtual), e (opcionalmente) o número da porta TCP na qual o servidor está ouvindo.
Referer
-
The address of the previous web page from which a link to the currently requested page was followed.
Referrer-Policy
-
Governs which referrer information sent in the
Referer
header should be included with requests made. User-Agent
-
Contains a characteristic string that allows the network protocol peers to identify the application type, operating system, software vendor or software version of the requesting software user agent. See also the Firefox user agent string reference.
Contexto da resposta
Requisições Range
Accept-Ranges
-
Indica se o servidor suporta solicitações de intervalo, se sim, em qual unidade o intervalo pode ser expresso.
Range
-
Indica a parte de um documento que o servidor deve retornar.
If-Range
-
Cria uma solicitação de intervalo condicional que é atendida se a etag ou data fornecida no parâmetro corresponde ao recurso remoto. Usado para impedir o download de dois intervalos da versão incompatível do recurso.
Content-Range
-
Indica onde uma parte da mensagem faz parte de uma mensagem inteira de corpo.
Segurança
Content-Security-Policy
(CSP)-
Controls resources the user agent is allowed to load for a given page.
Content-Security-Policy-Report-Only
-
Allows web developers to experiment with policies by monitoring (but not enforcing) their effects. These violation reports consist of JSON documents sent via an HTTP
POST
request to the specified URI. Public-Key-Pins
(HPKP)-
Associates a specific cryptographic public key with a certain web server to decrease the risk of MITM attacks with forged certificates.
Public-Key-Pins-Report-Only
-
Sends reports to the report-uri specified in the header and does still allow clients to connect to the server even if the pinning is violated.
Strict-Transport-Security
(HSTS)-
Force communication using HTTPS instead of HTTP.
Upgrade-Insecure-Requests
-
Sends a signal to the server expressing the client's preference for an encrypted and authenticated response, and that it can successfully handle the
upgrade-insecure-requests
directive. X-Content-Type-Options
-
Disables MIME sniffing and forces browser to use the type given in
Content-Type
. X-Frame-Options
(XFO)-
Indicates whether or not a browser should be allowed to render a page in a
<frame>
,<iframe>
or<object>
X-XSS-Protection
-
Enables cross-site scripting filtering.
Server-sent events
Ping-From
-
...
Ping-To
-
...
Last-Event-ID
-
...
Transfer coding
Transfer-Encoding
-
Specifies the the form of encoding used to safely transfer the entity to the user.
TE
-
Specifies the transfer encodings the user agent is willing to accept.
Trailer
-
Allows the sender to include additional fields at the end of chunked message.
WebSockets
Outros
Date
-
Contém a data e hora em que a mensagem foi produzida.
Link
-
...
Retry-After
-
Indica quanto tempo o User-Agent deve esperar antes de realizar uma requisição de acompanhamento.
Upgrade
-
This is a Proposed Internet Standard. To view a comprehensive list of all Official and Proposed Internet Standards with detailed information about each, visit this Internet Standards reference, which is updated daily. The relevant RFC document for the Upgrade header field standard is RFC 7230, section 6.7. The standard establishes rules for upgrading or changing to a different protocol on the current client, server, transport protocol connection. For example, this header standard allows a client to change from HTTP 1.1 to HTTP 2.0, assuming the server decides to acknowledge and implement the Upgrade header field. Niether party is required to accept the terms specified in the Upgrade header field. It can be used in both client and server headers. If the Upgrade header field is specified, then the sender MUST also send the Connection header field with the upgrade option specified. For details on the Connection header field please see section 6.1 of the aforementioned RFC.
Vary
-
Determines how to match future request headers to decide whether a cached response can be used rather than requesting a fresh one from the origin server.
X-Content-Duration
-
...
X-DNS-Prefetch-Control
-
Controls DNS prefetching, a feature by which browsers proactively perform domain name resolution on both links that the user may choose to follow as well as URLs for items referenced by the document, including images, CSS, JavaScript, and so forth.
X-Requested-With
-
...
X-UA-Compatible
-
...