❌

Normal view

There are new articles available, click to refresh the page.
Before yesterdayMain stream

Learning Notes #64 – E-Tags and Last-Modified Headers

20 January 2025 at 16:57

Today morning, i started with a video on E-Tags (came as first in youtube suggestion). In this blog i jot down my notes on E-Tags and how it helps in saving bandwidth. Also how Last-Modified header is better than E-Tags.

In the world of web development, ensuring efficient resource management and improved performance is crucial. Two key mechanisms that help in achieving this are E-Tags (Entity Tags) and the Last-Modified header.

These HTTP features facilitate caching and conditional requests, reducing bandwidth usage and improving user experience.

What is an E-Tag?

An Entity Tag (E-Tag) is an HTTP header used for web cache validation. It acts as a unique identifier for a specific version of a resource on the server. When a resource changes, its E-Tag also changes, enabling clients (e.g., browsers) to determine if their cached version of the resource is still valid.

How E-Tags Work

1. Response with E-Tag: When a client requests a resource, the server responds with the resource and an E-Tag in the HTTP header.


HTTP/1.1 200 OK
ETag: "abc123"
Content-Type: application/json
Content-Length: 200

2. Subsequent Requests: On subsequent requests, the client includes the E-Tag in the If-None-Match header.


GET /resource HTTP/1.1
If-None-Match: "abc123"

3. Server Response

If the resource hasn’t changed, the server responds with a 304 Not Modified status, saving bandwidth,


HTTP/1.1 304 Not Modified

If the resource has changed, the server responds with a 200 OK status and a new E-Tag,


HTTP/1.1 200 OK
ETag: "xyz789"

Benefits of E-Tags

  • Precise cache validation based on resource version.
  • Reduced bandwidth usage as unchanged resources are not re-downloaded.
  • Improved user experience with faster loading times for unchanged resources.

What is the Last-Modified Header?

The Last-Modified header indicates the last time a resource was modified on the server. It’s a simpler mechanism compared to E-Tags but serves a similar purpose in caching and validation.

How Last-Modified Works

1. Response with Last-Modified: When a client requests a resource, the server includes the Last-Modified header in its response,


HTTP/1.1 200 OK
Last-Modified: Wed, 17 Jan 2025 10:00:00 GMT
Content-Type: image/png
Content-Length: 1024

    2. Subsequent Requests: On future requests, the client includes the If-Modified-Since header.

    
    GET /image.png HTTP/1.1
    If-Modified-Since: Wed, 17 Jan 2025 10:00:00 GMT
    

    3. Server Response

    If the resource hasn’t changed, the server responds with a 304 Not Modified status,

    
    HTTP/1.1 304 Not Modified
    

    If the resource has changed, the server sends the updated resource with a new Last-Modified value,

    
    HTTP/1.1 200 OK
    Last-Modified: Thu, 18 Jan 2025 12:00:00 GMT
    

    E-Tags and Last-Modified headers are powerful tools for improving web application performance. By enabling conditional requests and efficient caching, they reduce server load and bandwidth usage while enhancing the user experience. Remember, these 2 are pretty old mechanisms, which are been used tilldate.

    HTML Tags Ordered Alphabetically

    By: Sakthivel
    24 August 2024 at 03:06
    TagDescription
    <!–…–>Defines a comment
    <!DOCTYPE>Β Defines the document type
    <a>Defines a hyperlink
    <abbr>Defines an abbreviation or an acronym
    <acronym>Not supported in HTML5. Use <abbr> instead.
    Defines an acronym
    <address>Defines contact information for the author/owner of a document
    <applet>Not supported in HTML5. Use <embed> or <object> instead.
    Defines an embedded applet
    <area>Defines an area inside an image map
    <article>Defines an article
    <aside>Defines content aside from the page content
    <audio>Defines embedded sound content
    <b>Defines bold text
    <base>Specifies the base URL/target for all relative URLs in a document
    <basefont>Not supported in HTML5. Use CSS instead.
    Specifies a default color, size, and font for all text in a document
    <bdi>Isolates a part of text that might be formatted in a different direction from other text outside it
    <bdo>Overrides the current text direction
    <big>Not supported in HTML5. Use CSS instead.
    Defines big text
    <blockquote>Defines a section that is quoted from another source
    <body>Defines the document’s body
    <br>Defines a single line break
    <button>Defines a clickable button
    <canvas>Used to draw graphics, on the fly, via scripting (usually JavaScript)
    <caption>Defines a table caption
    <center>Not supported in HTML5. Use CSS instead.
    Defines centered text
    <cite>Defines the title of a work
    <code>Defines a piece of computer code
    <col>Specifies column properties for each column within a <colgroup> elementΒ 
    <colgroup>Specifies a group of one or more columns in a table for formatting
    <data>Adds a machine-readable translation of a given content
    <datalist>Specifies a list of pre-defined options for input controls
    <dd>Defines a description/value of a term in a description list
    <del>Defines text that has been deleted from a document
    <details>Defines additional details that the user can view or hide
    <dfn>Specifies a term that is going to be defined within the content
    <dialog>Defines a dialog box or window
    <dir>Not supported in HTML5. Use <ul> instead.
    Defines a directory list
    <div>Defines a section in a document
    <dl>Defines a description list
    <dt>Defines a term/name in a description list
    <em>Defines emphasized textΒ 
    <embed>Defines a container for an external application
    <fieldset>Groups related elements in a form
    <figcaption>Defines a caption for a <figure> element
    <figure>Specifies self-contained content
    <font>Not supported in HTML5. Use CSS instead.
    Defines font, color, and size for text
    <footer>Defines a footer for a document or section
    <form>Defines an HTML form for user input
    <frame>Not supported in HTML5.
    Defines a window (a frame) in a frameset
    <frameset>Not supported in HTML5.
    Defines a set of frames
    <h1> to <h6>Defines HTML headings
    <head>Contains metadata/information for the document
    <header>Defines a header for a document or section
    <hgroup>Defines a header and related content
    <hr>Defines a thematic change in the content
    <html>Defines the root of an HTML document
    <i>Defines a part of text in an alternate voice or mood
    <iframe>Defines an inline frame
    <img>Defines an image
    <input>Defines an input control
    <ins>Defines a text that has been inserted into a document
    <kbd>Defines keyboard input
    <label>Defines a labelΒ for an <input> element
    <legend>Defines a caption for a <fieldset> element
    <li>Defines a list item
    <link>Defines the relationship between a document and an external resource (most used to link to style sheets)
    <main>Specifies the main content of a document
    <map>Defines an image map
    <mark>Defines marked/highlighted text
    <menu>Defines an unordered list
    <meta>Defines metadata about an HTML document
    <meter>Defines a scalar measurement within a known range (a gauge)
    <nav>Defines navigation links
    <noframes>Not supported in HTML5.
    Defines an alternate content for users that do not support frames
    <noscript>Defines an alternate content for users that do not support client-side scripts
    <object>Defines a container for an external application
    <ol>Defines an ordered list
    <optgroup>Defines a group of related options in a drop-down list
    <option>Defines an option in a drop-down list
    <output>Defines the result of a calculation
    <p>Defines a paragraph
    <param>Defines a parameter for an object
    <picture>Defines a container for multiple image resources
    <pre>Defines preformatted text
    <progress>Represents the progress of a task
    <q>Defines a short quotation
    <rp>Defines what to show in browsers that do not support ruby annotations
    <rt>Defines an explanation/pronunciation of characters (for East Asian typography)
    <ruby>Defines a ruby annotation (for East Asian typography)
    <s>Defines text that is no longer correct
    <samp>Defines sample output from a computer program
    <script>Defines a client-side script
    <search>Defines a search section
    <section>Defines a section in a document
    <select>Defines a drop-down list
    <small>Defines smaller text
    <source>Defines multiple media resources for media elements (<video> and <audio>)
    <span>Defines a section in a document
    <strike>Not supported in HTML5. Use <del> or <s> instead.
    Defines strikethrough text
    <strong>Defines important text
    <style>Defines style information for a document
    <sub>Defines subscripted text
    <summary>Defines a visible heading for a <details> element
    <sup>Defines superscripted text
    <svg>Defines a container for SVG graphics
    <table>Defines a table
    <tbody>Groups the body content in a table
    <td>Defines a cell in a table
    <template>Defines a container for content that should be hidden when the page loads
    <textarea>Defines a multiline input control (text area)
    <tfoot>Groups the footer content in a table
    <th>Defines a header cell in a table
    <thead>Groups the header content in a table
    <time>Defines a specific time (or datetime)
    <title>Defines a title for the document
    <tr>Defines a row in a table
    <track>Defines text tracks for media elements (<video> and <audio>)
    <tt>Not supported in HTML5. Use CSS instead.
    Defines teletype text
    <u>Defines some text that is unarticulated and styled differently from normal text
    <ul>Defines an unordered list
    <var>Defines a variable
    <video>Defines embedded video content
    <wbr>Defines a possible line-break

    ❌
    ❌