In dieser Anleitung wird erklärt, wie Sie eine Signatur erstellen und welche Felder für Signaturen erforderlich und optional sind.
Zum Erstellen einer Signatur erstellen Sie einen zu signierenden String, der in dieser Anleitung als signierter Wert bezeichnet wird. Der signierte Wert enthält Parameter zur Beschreibung des zu schützenden Inhalts, die Ablaufzeit des signierten Werts usw.
Sie verwenden den signierten Wert beim Erstellen eines Signaturstrings. Zum Erstellen eines Signaturstrings erstellen Sie die Parameter für die Signatur, z. B. eine Signatur mit dem asymmetrischen Schlüssel für Ed25519 des signierten Werts.
Media CDN verwendet die endgültige zusammengesetzte Signatur, um Ihre Inhalte zu schützen.
Unterstützte Signaturformate
Media CDN unterstützt die folgenden signierten Anfrageformate:
Format | Verhalten | Beispiel |
---|---|---|
Suchparameter (genaue URL) |
Genaue URL zum Gewähren des Zugriffs auf eine bestimmte URL. |
Exakt:
|
Suchparameter (URL-Präfix) |
Durch Angabe eines URLPrefix können Sie ein Präfix signieren und dieselben Abfrageparameter an mehrere URLs innerhalb der Spieler- oder Manifest-Generierung anhängen.
|
Signieren:
Ersetzen Sie |
Pfadkomponente |
Präfix: Ermöglicht den Zugriff auf jede URL mit einem Präfix vor der Komponente Dadurch können relative Manifest-URLs die Komponente der signierten URL beim Abrufen von Unterressourcen automatisch übernehmen. |
https://media.example.com/video/edge-cache-token=Expires=EXPIRATION
|
Signiertes Cookie | Präfix: Das Cookie ermöglicht den Zugriff auf jede URL mit dem Präfix, das im signierten URLPrefix -Wert angegeben ist.
|
Edge-Caching-Cookie:
|
Signatur erstellen
Erstellen Sie einen signierten Wert. Verketten Sie dazu einen String, der die erforderlichen Signaturfelder und die gewünschten optionalen Signaturfelder enthält.
Falls angegeben, muss
URLPrefix
an erster Stelle stehen, gefolgt vonExpires
,KeyName
und dann allen optionalen Parametern.Trennen Sie die einzelnen Felder und alle Parameter durch Folgendes:
- Verwenden Sie für Cookies einen Doppelpunkt
:
. - Verwenden Sie für Abfrageparameter und Pfadkomponenten ein Und-Zeichen
&
.
- Verwenden Sie für Cookies einen Doppelpunkt
Signiert den Wert mit einer Ed25519-Signatur.
Hängen Sie an das Ende des Strings ein Feldtrennzeichen (entweder
:
oder&
) gefolgt vonSignature=
und der Ed25519-Signatur.
Signierte URLs erstellen
Im folgenden Python-Codebeispiel wird gezeigt, wie signierte URLs programmatisch erstellt werden:
Erforderliche Signaturfelder
Die folgenden Felder sind für jede Signatur erforderlich:
Expires
KeyName
Signature
Wenn Abfrageparameter vorhanden sind, müssen sie als letzte Parameter in der URL gruppiert werden. Wenn nicht anders angegeben, wird bei Parameternamen und ihren Werten die Groß-/Kleinschreibung beachtet.
In der folgenden Tabelle werden die einzelnen Parameter erläutert:
Feldname | Signaturparameter | Signierter Wert |
---|---|---|
Expires |
Ganzzahlsekunden, die seit der Unix-Epoche verstrichen sind (1970-01-01T00:00:00Z) | Expires=EXPIRATION_TIME , danach ist die Signatur nicht mehr gültig. |
KeyName |
Der Name des EdgeCacheKeyset , der zum Signieren dieser Anfrage verwendet wird. KeyName bezieht sich auf das gesamte Keyset und nicht auf einzelne Schlüssel im Schlüsselsatz selbst.
|
KeyName=EDGE_CACHE_KEYSET |
Signature |
Eine base64-codierte Version der Signatur. | Nicht zutreffend |
Optionale Signaturfelder
Wenn Abfrageparameter vorhanden sind, müssen sie als letzte Parameter in der URL gruppiert werden. Wenn nicht anders angegeben, wird bei Parameternamen und ihren Werten die Groß-/Kleinschreibung beachtet.
In der folgenden Tabelle werden der Name und die Details der einzelnen Parameter für optionale Signaturparameter erläutert:
Feldname | Signaturparameter | Signierter Wert |
---|---|---|
HeaderName |
Ein benannter Feldname des Anfrageheaders, der in der Anfrage vorhanden sein muss. Beim Signieren muss ein Kleinbuchstabe verwendet werden, da die Namen von Headerfeldern die Groß-/Kleinschreibung berücksichtigen. Media CDN verwendet den Header vor der Validierung der Signatur in Kleinbuchstaben. |
HeaderName=HEADER_NAME |
HeaderValue |
Ein benannter Wert des Anfrageheaderfelds, der in der Anfrage vorhanden sein muss. Dies ist im Allgemeinen eine Nutzer-ID oder eine andere intransparente Kennzeichnung. Anfragen mit HeaderValue , aber ohne HeaderName werden abgelehnt.
|
HeaderValue=HEADER_VALUE |
IPRanges |
Eine Liste mit bis zu fünf IPv4- und IPv6-Adressen im CIDR-Format, für die diese URL im websicheren Base64-Format gültig ist. Geben Sie beispielsweise Die Aufnahme von IPRanges in die Signaturen ist möglicherweise nicht sinnvoll, wenn Kunden von WAN-Migrationen bedroht sind oder wenn der Netzwerkpfad zu Ihrem Anwendungs-Front-End ein anderer ist als der Bereitstellungspfad.
Media CDN lehnt Clients mit einem Die folgenden Fälle können dazu führen, dass Media CDN Clients mit einem
All diese Faktoren können dazu beitragen, dass ein bestimmter Client während einer Videowiedergabesitzung eine nicht-deterministische IP-Adresse hat. Wenn sich die IP-Adresse des Clients ändert, nachdem Sie den Zugriff gewährt haben, und der Client versucht, ein Videosegment in seinen Wiedergabepuffer herunterzuladen, erhält er ein |
IPRanges=BASE_64_IP_RANGES |
URLPrefix |
Das base64-URL-Präfix, auf das zugegriffen werden soll. Durch die Angabe eines URLPrefix können Sie ein Präfix signieren und dieselben Abfrageparameter an mehrere URLs innerhalb Ihres Players oder Ihrer Manifestgenerierung anhängen.
URLPrefix ist erforderlich, wenn Sie das signierte Cookieformat verwenden.
|
URLPrefix=BASE_64_URL_PREFIX |