Questa guida spiega come creare una firma e i campi obbligatori e facoltativi per le firme.
Per creare una firma, componi una stringa da firmare, che in questa guida chiamiamo valore firmato. Il valore firmato include parametri che descrivono i contenuti che stai proteggendo, il tempo di scadenza del valore firmato e così via.
Utilizzi il valore firmato durante la creazione di una stringa di firma. Crea una stringa di firma componendo i parametri della firma, ad esempio una firma Ed25519 con chiave asimmetrica del valore firmato.
Media CDN utilizza la firma composta finale per proteggere i tuoi contenuti.
Formati di firma supportati
Media CDN supporta i seguenti formati di richiesta firmata.
Formato | Comportamento | Esempio |
---|---|---|
Parametri di query (URL esatto) |
URL esatto, per concedere l'accesso a un URL specifico. |
Esatta:
|
Parametri di query (prefisso URL) |
La specifica di un URLPrefix consente di firmare un prefisso e aggiungere
gli stessiparametri di ricercay a più URL all'interno del lettore o della generazione del manifest.
|
Cosa firmare:
Sostituisci |
Componente percorso |
Prefisso: consente l'accesso a qualsiasi URL con un prefisso precedente al componente
In questo modo, gli URL manifest relativi ereditano automaticamente il componente URL firmato durante il recupero delle risorse secondarie. |
https://media.example.com/video/edge-cache-token=Expires=EXPIRATION
|
Cookie firmato | Prefisso: il cookie consente l'accesso a qualsiasi URL con il prefisso specificato
nel valore URLPrefix firmato.
|
Edge-Cache-Cookie:
|
Crea una firma
Crea un valore firmato concatenando una stringa che contiene i campi della firma obbligatori e i campi della firma facoltativi desiderati.
Se specificato,
URLPrefix
deve essere il primo, seguito daExpires
,KeyName
e poi da eventuali parametri facoltativi.Separa ogni campo e tutti i parametri con i seguenti simboli:
- Per i cookie, utilizza i due punti
:
. - Per parametri di ricerca e i componenti del percorso, utilizza il carattere e commerciale
&
.
- Per i cookie, utilizza i due punti
Firma il valore firmato con una firma Ed25519.
Aggiungi un separatore di campo (
:
o&
) seguito daSignature=
e dalla firma Ed25519 alla fine della stringa.
Crea un URL firmato
I seguenti esempi di codice mostrano come creare un URL firmato in modo programmatico.
Go
Per eseguire l'autenticazione in Media CDN, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per un ambiente di sviluppo locale.
Python
Per eseguire l'autenticazione in Media CDN, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per un ambiente di sviluppo locale.
Creare un prefisso URL firmato
I seguenti esempi di codice mostrano come creare a livello di programmazione un prefisso URL firmato.
Go
Per eseguire l'autenticazione in Media CDN, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per un ambiente di sviluppo locale.
Python
Per eseguire l'autenticazione in Media CDN, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per un ambiente di sviluppo locale.
Crea un cookie con URL firmato
I seguenti esempi di codice mostrano come creare in modo programmatico un cookie URL firmato.
Go
Per eseguire l'autenticazione in Media CDN, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per un ambiente di sviluppo locale.
Python
Per eseguire l'autenticazione in Media CDN, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per un ambiente di sviluppo locale.
Creare un componente del percorso firmato
I seguenti esempi di codice mostrano come creare a livello di programmazione un componente del percorso firmato.
Python
Per eseguire l'autenticazione in Media CDN, configura le Credenziali predefinite dell'applicazione. Per ulteriori informazioni, vedi Configura l'autenticazione per un ambiente di sviluppo locale.
Campi della firma obbligatori
I seguenti campi sono obbligatori per ogni firma:
Expires
KeyName
Signature
Se sono presenti parametri di ricerca, devono essere raggruppati come ultimi parametri nell'URL. Se non diversamente specificato, i nomi dei parametri e i relativi valori sono sensibili alle maiuscole.
La tabella seguente descrive ciascun parametro:
Nome campo | Parametri della firma | Valore firmato |
---|---|---|
Expires |
Secondi interi trascorsi dall'epoca di Unix (1970-01-01T00:00:00Z) | Expires=EXPIRATION_TIME , dopo la quale la
firma non è più valida. |
KeyName |
Il nome del EdgeCacheKeyset utilizzato per firmare questa
richiesta. KeyName si riferisce all'intero set di chiavi, non
alle singole chiavi all'interno del set stesso.
|
KeyName=EDGE_CACHE_KEYSET |
Signature |
Una versione della firma con codifica Base64. | Non applicabile |
Campi della firma facoltativi
Se sono presenti parametri di ricerca, devono essere raggruppati come ultimi parametri nell'URL. Se non diversamente specificato, i nomi dei parametri e i relativi valori sono sensibili alle maiuscole.
La seguente tabella spiega il nome e i dettagli di ciascun parametro per i parametri di firma facoltativi:
Nome campo | Parametri della firma | Valore firmato |
---|---|---|
HeaderName |
Il nome di un campo di intestazione della richiesta denominato che deve essere presente nella richiesta. Deve essere in minuscolo quando viene firmato perché i nomi dei campi delle intestazioni sono sensibili alle maiuscole. Media CDN converte l'intestazione in minuscolo prima di convalidare la firma. |
HeaderName=HEADER_NAME |
HeaderValue |
Un valore del campo di intestazione della richiesta denominato che deve essere presente nella
richiesta. In genere si tratta di un ID utente o di un altro identificatore opaco. Le richieste
con HeaderValue ma senza HeaderName vengono
rifiutate.
|
HeaderValue=HEADER_VALUE |
IPRanges |
Un elenco di massimo cinque indirizzi IPv4 e IPv6 in formato CIDR per
cui questo URL è valido in formato base64 sicuro per il web. Ad esempio,
per specificare gli intervalli IP "192.6.13.13/32,193.5.64.135/32", specifica
Gli intervalli IP potrebbero non essere utili da includere nelle firme quando i client
sono a rischio di migrazioni WAN o nei casi in cui il percorso di rete al frontend
dell'applicazione è diverso dal percorso di distribuzione.
Media CDN rifiuta i client con un codice Di seguito sono riportati i casi che potrebbero comportare il rifiuto dei client da parte di Media CDN con un codice
Tutti questi fattori possono contribuire a far sì che un determinato client abbia un
indirizzo IP non deterministico durante una sessione di riproduzione video. Se l'indirizzo IP del client cambia dopo che hai concesso l'accesso e il client tenta di scaricare un segmento video nel buffer di riproduzione, riceve un |
IPRanges=BASE_64_IP_RANGES |
URLPrefix |
Il prefisso URL base64 (con protezione dell'URL) a cui concedere l'accesso. Se specifichi un
URLPrefix , puoi firmare un prefisso e aggiungere gli stessi parametri di query
a più URL durante la generazione del lettore o del manifest.
URLPrefix è obbligatorio quando si utilizza il formato
del cookie firmato.
|
URLPrefix=BASE_64_URL_PREFIX |