Un token web JSON (JWT) è uno standard web aperto utilizzato per l'autenticazione e l'autorizzazione degli scambi di informazioni tra un client e un server. Quando un utente dell'app esegue l'accesso per la prima volta con le credenziali del ruolo appropriate, il server crea e restituisce un JWT codificato e firmato digitalmente da utilizzare con le richieste successive. Questa procedura autentica l'utente e lo autorizza ad accedere a route, servizi e risorse in base al ruolo dell'account.
Fleet Engine richiede l'utilizzo di token web JSON (JWT) per le chiamate ai metodi API da ambienti a bassa attendibilità: smartphone e browser.
Un JWT ha origine sul server, viene firmato, criptato e passato al client per le interazioni successive con il server fino alla scadenza o alla perdita di validità.
Dettagli chiave
- Utilizza le credenziali predefinite dell'applicazione per l'autenticazione e l'autorizzazione in Fleet Engine.
- Utilizza un account di servizio appropriato per firmare i JWT. Consulta i ruoli dei service account di Fleet Engine in Nozioni di base su Fleet Engine.
A differenza delle chiavi API, i JWT hanno una durata breve e limitano le operazioni solo a quelle che il ruolo è autorizzato a eseguire. Per saperne di più sui JWT, consulta Token web JSON su Wikipedia. Per informazioni dettagliate sui ruoli di accesso, consulta Ruoli dei service account in questa guida.
Elementi JWT
I JWT contengono un'intestazione e una sezione di rivendicazione. La sezione dell'intestazione contiene informazioni come la chiave privata ottenuta dai service account e l'algoritmo di crittografia. La sezione di rivendicazione contiene informazioni come l'ora di creazione del JWT, la durata, i servizi a cui il JWT rivendica l'accesso e altre informazioni di autorizzazione per limitare l'accesso, ad esempio l'ID del veicolo di consegna.
La tabella seguente fornisce dettagli descrittivi sui campi JWT in generale, nonché informazioni specifiche su dove trovare i valori di questi campi nel tuo progetto Cloud di Fleet Engine.
Campo |
Descrizione |
|---|---|
alg |
L'algoritmo da utilizzare. `RS256`. |
typ |
Il tipo di token. `JWT`. |
kid |
L'ID della chiave privata del tuo service account. Puoi trovare questo valore nel
|
Campo |
Descrizione |
|---|---|
iss |
L'indirizzo email del tuo service account, che si trova nel
|
sub |
L'indirizzo email del tuo service account, che si trova nel
|
aud |
Il |
iat |
Il timestamp di creazione del JWT, specificato in secondi
trascorsi dalle 00:00:00 |
exp |
Il timestamp di scadenza del JWT, specificato in secondi trascorsi
dalle |
authorization |
A seconda del caso d'uso, può contenere Se specifichi taskids, l'ambito di autorizzazione deve essere un array in uno dei seguenti formati: "taskids": ["task_id_one","task_id_two"]
o "taskids": ["*"] |
Rivendicazioni JWT di Fleet Engine
Fleet Engine utilizza rivendicazioni private. L'utilizzo di rivendicazioni private garantisce che solo i client autorizzati possano accedere ai propri dati.
Ad esempio, quando il server emette un token web JSON per il dispositivo mobile di un conducente, deve contenere la rivendicazione vehicleid o la
deliveryvehicleid rivendicazione con il valore dell'ID del veicolo del conducente. A seconda del ruolo del conducente, i JWT consentono l'accesso solo all'ID del veicolo specifico e non a qualsiasi altro ID del veicolo arbitrario.
Fleet Engine utilizza le seguenti rivendicazioni private:
Viaggi on demand
-
vehicleid:- Driver SDK utilizza sempre questa rivendicazione, sia che operi su un viaggio che su un veicolo. Il backend di Fleet Engine garantisce che il veicolo sia associato al viaggio richiesto prima di apportare la modifica.
- Il JWT può coprire sia le operazioni sui veicoli che sui viaggi operazioni, anche se non è obbligatorio, il che può semplificare l'implementazione della firma JWT implementazione.
-
tripid:- Consumer SDK utilizza sempre questa rivendicazione.
- Il JWT può coprire sia le operazioni sui veicoli che sui viaggi, anche se non è obbligatorio, il che può semplificare l'implementazione della firma del token.
Attività pianificate
-
deliveryvehicleidUtilizza quando chiami le API per veicolo di consegna.
-
taskidUtilizza quando chiami le API per attività.
-
taskidsUtilizza quando chiami
BatchCreateTasksAPI. Questa attestazione deve essere in formato array, e l'array deve contenere tutti gli ID attività necessari per completare la richiesta. Non includere le rivendicazionidelivervehicleid,trackingid, otaskid. -
trackingidUtilizza quando chiami il
GetTaskTrackingInfoAPI. La rivendicazione deve corrispondere all'ID di monitoraggio nella richiesta. Non includere le rivendicazionidelivervehicleid,taskid, otaskids.
Passaggi successivi
- Leggi la sezione Progettazione della sicurezza di Fleet Engine per comprendere il flusso di autenticazione completo.
- Scopri come emettere token web JSON dal tuo server.