Logo

dev-resources.site

for different kinds of informations.

HTTP Headers Explained

Published at
4/12/2020
Categories
http
header
Author
spukas
Categories
2 categories in total
http
open
header
open
Author
6 person written this
spukas
open
HTTP Headers Explained

HTTP Request and Response objects consist of body and header. While the body in the Response holds the data message (HTML, JSON) or form fields in the Request, the headers let the client and the server to pass essential information about each other.

Headers can be grouped into four categories by their context:

  • General headers contain information that is relevant for both request and Response, but no information about the data in a body
  • Request headers hold information about the client and requested resource
  • Response headers include server details, like time, location, configuration
  • Entity header informs browser about the type and body of the resource

Let’s inspect more in details. Go to the webpage www.example.com, open the console > Network tab, and select the document to inspect headers. You will likely see the headers divided into General, Request, and Response.

The first, General group consist of the following information:

  • Request URL: https://www.example.com
    The address of the Request and Response

  • Request Method: GET
    A method that is used for the operation, like GET, POST, PUT or DELETE

  • Status Code: 200 OK
    One of the most critical information that tells the status of the request/response. The different code number says what happened, did the operation succeeded or failed. Status codes are grouped:
    1xx - Informational; the request is processing
    2xx - Success; received, accepted, created
    3xx - Redirect; actions needed, moved to a new location
    4xx - Client Error; bad request, unauthorized or not found
    5xx - Server Error; server failed to fulfill the request, internal server error

  • Remote Address: 93.184.216.34:80
    The IP address of the server

Another group is Request Headers includes following properties:

  • Accept: text/html
    Informs the server, what data types can be accepted, describes the content format. For example:
    audio/ogg indicates an audio file
    image/png - an image file
    text/html - HTML file
    application/json - data in the JSON format

  • Accept-Encoding: gzip, deflate
    An algorithm, such as compression that is used on the recourse sent back.

  • Accept-Language: en-US,en
    Hints the server about the expected language

  • Connection: keep-alive
    Controls how long connection should stay open

  • Host: example.com
    The domain name of the server

  • User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_4)
    Lets server to identify the characteristics of the application, OS, vendor, and versions

Some of the important and common Request Header properties were not included from the domain example.com, but they should be mentioned:

  • Cookie: 'cookie-list'
    Contains stored piece of information, previously sent by the server. For example: Cookie: name=value; name2=value2; name3=value3

  • Authorization: 'type' 'credentials'
    Includes credentials to authenticate a user with a server. The two most used types are Basic, for base64-encoded credentials, and Bearer for access tokens.

  • Referer: 'url'
    Contains the address of the previous page, from which the user was linked to the current page

The last group is Response Headers includes:

  • Age: 270773
    Time in seconds how long the object was in the proxy cache

  • Cache-Control: max-age=604800
    Set the instruction for caching. Other setting types: no-cache, no-store, no-transform

  • Content-Encoding: gzip
    Specifies the compression algorithm used for the response body

  • Content-Length: 648
    The size of the recourse in bytes

  • Content-Type: text/html; charset=UTF-8
    The resource type received. The current type is an HTML document.

  • Date: Sun, 12 Apr 2020 16:49:25 GMT
    The time when the message was created

  • Expires: Sun, 19 Apr 2020 16:49:25 GMT
    Sets the date when the relevant content will no longer be new/fresh

  • Server: ECS (nyb/1D2C)
    Specifies the software used by the server at the time of the sent Response

  • X-Cache: HIT
    It means that the request was sent not from the origin servers, but from an exclusive network (CDN), designed to cache content, so the user could get Response faster

  • Set-Cookie: 'cookie-name=cookie-value'
    Sent cookies from the server to the user-agent. May include other cookie settings, such as expiration date, max-age, domain, security. For example: Set-Cookie: id=qwerty123; Expires=Wed, 13 Apr 2020 07:00:00 GMT

Summing up

The Request and Response headers carry and define transaction information about the user agent, server and data. These headers in the example were the more common ones, there are a lot more of them. The complete list can be found here.

header Article's
30 articles in total
Favicon
Header in React
Favicon
Header in React
Favicon
Empty Excel Folders for Python programming
Favicon
Using cURL Custom Headers: A Simple Guide
Favicon
Comment ajouter un en-tΓͺte et un pied de page Γ  Word avec Python
Favicon
Solve the error "header files not found. no such file or directory".
Favicon
Understanding Word Header and Footer: Professional Advice for java developers
Favicon
How to Create a Resume Header [7+ Examples]
Favicon
HTML table sticky header with borders
Favicon
Java-How to Add or Remove Header and Footer in Word documents
Favicon
Remember to set Cache-Control headers on your secured pages
Favicon
CSS Shopping cart Icon with number of items.
Favicon
How to make a dynamic Twitter Header with Switchboard Canvas
Favicon
How to create header/footer (using HTML) in each page
Favicon
backdrop-filter: blur / header sticky
Favicon
Manage License Headers with Ease
Favicon
HTML tags | header
Favicon
[Java] Add Different Headers/Footers for Odd and Even Pages in Word
Favicon
SpringBoot RabbitMq Headers Exchange
Favicon
Insert Header and Footer to Word using Java
Favicon
Answer: How to specify column names while reading an Excel file using Pandas?
Favicon
Make a Material table header fix
Favicon
Sticky navbar from scratch using react
Favicon
So hard to make table header sticky
Favicon
How to remove IIS server information from the response header?
Favicon
Global Header in Swagger-Ui Spring-Boot
Favicon
HTTP Headers Explained
Favicon
Java add image and text header/footer to Excel
Favicon
Add Header and Footer to an Existing PDF Document in Java
Favicon
Security Headers to use on your webserver

Featured ones: