HTTP ETag

aus Wikipedia, der freien Enzyklopädie

Wechseln zu: Navigation, Suche

ETag (für entity tag, etwa Entitätmarke) ist ein im HTTP 1.1 eingeführtes Header-Feld. Es dient zur Bestimmung von Änderungen an der angeforderten Ressource und wird hauptsächlich zum Caching, also der Vermeidung redundanter Datenübertragungen, verwendet.

Inhaltsverzeichnis

[Bearbeiten] Spezifikation

Der ETag-Wert ist eine beliebige von Anführungszeichen umschlossenen Zeichenkette, die zusätzlich durch das Präfix „W/“ als schwaches ETag gekennzeichnet werden kann. Die spezifizierende BNF dazu:

ETag = "ETag" ":" entity-tag
entity-tag = [ weak ] opaque-tag
weak       = "W/"
opaque-tag = quoted-string
Starker ETag
Ein starker ETag darf nur dann von mehreren Entitäten einer Ressource geführt werden, falls diese absolut identisch (Bit für Bit) sind.
Schwacher ETag
Ein schwacher ETag (durch „W/“-Präfix gekennzeichnet) darf von mehreren Entitäten einer Ressource geführt werden, falls diese zueinander äquivalent sind, sich also semantisch nicht signifikant unterscheiden.

Häufig basiert die Generierung des ETag-Werts auf der systemspezifischen Inode, der Größe sowie des Zeitpunkts der letzten Änderung einer Datei.

[Bearbeiten] Vorgang

Bei der ersten Anfrage einer Ressource sendet der Server einen für diese Ressource spezifischen ETag-Wert im ETag-Header-Feld, der vom Client zusammen mit der Ressource lokal gespeichert wird. Bei einer erneuten Anfrage derselben Ressource sendet der Client in dem Header-Feld If-None-Match den zuvor gespeicherten ETag-Wert mit. Auf der Server-Seite wird nun der gesendete ETag-Wert mit dem aktuellen verglichen und bei Übereinstimmung mit dem Statuscode 304 beantwortet. Die Daten der Ressource werden in diesem Fall nicht mitgeschickt und der Client verwendet die lokal gespeicherten Daten.

[Bearbeiten] Probleme

In bestimmten Situationen kann sich der ETag negativ auswirken. Denn wenn der ETag anhand der Inodes generiert wird, ist dieser Wert nur auf diesem System gültig. Wenn jedoch eine Seite auf mehreren Servern verteilt ist (zwecks Server-Lastverteilung), kann eine erneute Anfrage des Client von einem anderen Server mit einem anderen ETag-Wert verarbeitet werden, was wiederum der Übertragung derselben Datei trotz ETags zufolge hat. Aus diesem Grund wird empfohlen, die Inode bei der Generierung des ETag-Werts außen vor zu lassen.

[Bearbeiten] Weblinks

Persönliche Werkzeuge
Buch erstellen
Andere Sprachen