Modalità di salvataggio dei dati |
|
|---|---|
| PUT | Scrivi o sostituisci i dati in un percorso definito, ad esempio fireblog/users/user1/<data> |
| PATCH | Aggiorna alcune delle chiavi per un percorso definito senza sostituire tutti i dati. |
| POST | Aggiungi a un elenco di dati nel nostro database Firebase. Ogni volta che inviamo una POST richiesta, il client Firebase genera una chiave univoca, ad esempio fireblog/users/<unique-id>/<data> |
| ELIMINA | Rimuovi i dati dal riferimento al database Firebase specificato. |
Scrittura dei dati con PUT
L'operazione di scrittura di base tramite l'API REST è PUT. Per
dimostrare il salvataggio dei dati, creeremo un'applicazione di blogging con post e utenti. Tutti i
dati della nostra applicazione verranno archiviati nel percorso `fireblog`, all'URL del database Firebase
`https://docs-examples.firebaseio.com/fireblog`.
Iniziamo salvando alcuni dati utente nel nostro database Firebase. Memorizzeremo ogni utente con un nome utente univoco
e memorizzeremo anche il suo nome completo e la data di nascita. Poiché ogni utente avrà un
nome utente univoco, è consigliabile utilizzare PUT anziché POST poiché
abbiamo già la chiave e non dobbiamo crearne una.
Utilizzando PUT, possiamo scrivere una stringa, un numero, un valore booleano, un array o qualsiasi oggetto JSON nel nostro database Firebase. In questo caso, gli passeremo un oggetto:
curl -X PUT -d '{
"alanisawesome": {
"name": "Alan Turing",
"birthday": "June 23, 1912"
}
}' 'https://docs-examples.firebaseio.com/fireblog/users.json'
Quando un oggetto JSON viene salvato nel database, le proprietà dell'oggetto vengono mappate automaticamente alle posizioni secondarie in modo nidificato. Se vai al nodo appena creato, vedrai il valore "Alan Turing". Possiamo anche salvare i dati direttamente in una posizione secondaria:
curl -X PUT -d '"Alan Turing"' \ 'https://docs-examples.firebaseio.com/fireblog/users/alanisawesome/name.json'
curl -X PUT -d '"June 23, 1912"' \ 'https://docs-examples.firebaseio.com/fireblog/users/alanisawesome/birthday.json'
I due esempi precedenti (scrittura del valore contemporaneamente a un oggetto e scrittura separata nelle posizioni secondarie) comporteranno il salvataggio degli stessi dati nel nostro database Firebase:
{
"users": {
"alanisawesome": {
"date_of_birth": "June 23, 1912",
"full_name": "Alan Turing"
}
}
}
Una richiesta riuscita sarà indicata da un codice di stato HTTP 200 OK e la
risposta conterrà i dati che abbiamo scritto nel database. Il primo esempio attiverà un solo evento sui client che guardano i dati, mentre il secondo esempio ne attiverà due. È importante notare che se i dati esistevano già nel percorso degli utenti, il primo approccio
avrebbe sovrascritti, ma il secondo metodo avrebbe modificato solo il valore di ogni nodo secondario separato
lasciando invariati gli altri nodi secondari. PUT è equivalente a
set() nel nostro SDK JavaScript.
Aggiornamento dei dati con PATCH
Utilizzando una richiesta PATCH, possiamo aggiornare elementi secondari specifici in una posizione senza
sovrascrivere i dati esistenti. Aggiungiamo il soprannome di Turing ai suoi dati utente con una PATCH
richiesta:
curl -X PATCH -d '{
"nickname": "Alan The Machine"
}' \
'https://docs-examples.firebaseio.com/fireblog/users/alanisawesome.json'
La richiesta precedente scriverà nickname nel nostro oggetto alanisawesome
senza eliminare gli elementi secondari name o birthday. Tieni presente che se avessimo
inviato una richiesta PUT qui invece, name e birthday
sarebbero stati eliminati perché non erano inclusi nella richiesta. I dati nel nostro database Firebase
ora hanno il seguente aspetto:
{
"users": {
"alanisawesome": {
"date_of_birth": "June 23, 1912",
"full_name": "Alan Turing",
"nickname": "Alan The Machine"
}
}
}
Una richiesta riuscita sarà indicata da un codice di stato HTTP 200 OK e la
risposta conterrà i dati aggiornati scritti nel database.
Firebase supporta anche gli aggiornamenti multi-percorso. Ciò significa che PATCH può ora aggiornare i valori in più posizioni nel database Firebase contemporaneamente, una funzionalità potente che ti aiuta a
denormalizzare i dati. Utilizzando gli aggiornamenti multi-percorso, possiamo aggiungere soprannomi sia ad Alan sia a Grace contemporaneamente:
curl -X PATCH -d '{
"alanisawesome/nickname": "Alan The Machine",
"gracehopper/nickname": "Amazing Grace"
}' \
'https://docs-examples.firebaseio.com/fireblog/users.json'
Dopo questo aggiornamento, sono stati aggiunti i soprannomi sia ad Alan sia a Grace:
{
"users": {
"alanisawesome": {
"date_of_birth": "June 23, 1912",
"full_name": "Alan Turing",
"nickname": "Alan The Machine"
},
"gracehop": {
"date_of_birth": "December 9, 1906",
"full_name": "Grace Hopper",
"nickname": "Amazing Grace"
}
}
}Tieni presente che il tentativo di aggiornare gli oggetti scrivendo oggetti con i percorsi inclusi comporterà un comportamento diverso. Diamo un'occhiata a cosa succede se proviamo ad aggiornare Grace e Alan in questo modo:
curl -X PATCH -d '{
"alanisawesome": {"nickname": "Alan The Machine"},
"gracehopper": {"nickname": "Amazing Grace"}
}' \
'https://docs-examples.firebaseio.com/fireblog/users.json'
Il risultato è un comportamento diverso, ovvero la sovrascrittura dell'intero nodo /fireblog/users:
{
"users": {
"alanisawesome": {
"nickname": "Alan The Machine"
},
"gracehop": {
"nickname": "Amazing Grace"
}
}
}Aggiornamento dei dati con richieste condizionali
Puoi utilizzare le richieste condizionali, l'equivalente REST delle transazioni, per aggiornare i dati in base al loro stato esistente. Ad esempio, se vuoi aumentare un contatore di voti positivi e vuoi assicurarti che il conteggio rifletta con precisione più voti positivi simultanei, utilizza una richiesta condizionale per scrivere il nuovo valore nel contatore. Anziché due scritture che modificano il contatore con lo stesso numero, una delle richieste di scrittura non va a buon fine e puoi riprovare a inviare la richiesta con il nuovo valore.- Per eseguire una richiesta condizionale in una posizione, recupera l'identificatore univoco dei dati correnti in quella posizione
o l'ETag. Se i dati cambiano in
quella posizione, cambia anche l'ETag. Puoi richiedere un ETag con qualsiasi
metodo diverso da
PATCH. L'esempio seguente utilizza una richiestaGET. La chiamata specifica dell'ETag nell'intestazione restituisce l'ETag della posizione specificata nella risposta HTTP.curl -i 'https://test.example.com/posts/12345/upvotes.json' -H 'X-Firebase-ETag: true'
HTTP/1.1 200 OK Content-Length: 6 Content-Type: application/json; charset=utf-8 Access-Control-Allow-Origin: * ETag: [ETAG_VALUE] Cache-Control: no-cache 10 // Current value of the data at the specified location
- Includi l'ETag restituito nella richiesta
PUToDELETEsuccessiva per aggiornare i dati che corrispondono specificamente a quel valore ETag. Seguendo il nostro esempio, per aggiornare il contatore a 11, ovvero 1 in più rispetto al valore iniziale recuperato di 10, e non riuscire a inviare la richiesta se il valore non corrisponde più, utilizza il seguente codice: Se il valore dei dati nella posizione specificata è ancora 10, l'ETag nella richiestacurl -iX PUT -d '11' 'https://[PROJECT_ID].firebaseio.com/posts/12345/upvotes.json' -H 'if-match:[ETAG_VALUE]'
PUTcorrisponde e la richiesta va a buon fine, scrivendo 11 nel database. Se la posizione non corrisponde più all'ETag, il che potrebbe verificarsi se un altro utente ha scritto un nuovo valore nel database, la richiesta non va a buon fine senza scrivere nella posizione. La risposta restituita include il nuovo valore e l'ETag.HTTP/1.1 200 OK Content-Length: 6 Content-Type: application/json; charset=utf-8 Access-Control-Allow-Origin: * Cache-Control: no-cache 11 // New value of the data at the specified location, written by the conditional request
HTTP/1.1 412 Precondition Failed Content-Length: 6 Content-Type: application/json; charset=utf-8 Access-Control-Allow-Origin: * ETag: [ETAG_VALUE] Cache-Control: no-cache 12 // New value of the data at the specified location
- Utilizza le nuove informazioni se decidi di riprovare a inviare la richiesta. Realtime Database non riprova automaticamente a inviare le richieste condizionali non riuscite. Tuttavia, puoi utilizzare il nuovo valore e l'ETag per creare una nuova richiesta condizionale con le informazioni restituite dalla risposta di errore.
Le richieste condizionali basate su REST implementano lo standard HTTP if-match. Tuttavia, differiscono dallo standard nei seguenti modi:
- Puoi fornire un solo valore ETag per ogni richiesta if-match, non più di uno.
- Sebbene lo standard suggerisca di restituire gli ETag con tutte le richieste,
Realtime Database restituisce gli ETag solo con le richieste che includono l'
X-Firebase-ETagintestazione. Ciò riduce i costi di fatturazione per le richieste standard.
Le richieste condizionali potrebbero anche essere più lente delle richieste REST tipiche.
Salvataggio degli elenchi di dati
Per generare una chiave univoca basata sul timestamp per ogni elemento secondario aggiunto a un riferimento al database Firebase
possiamo inviare una richiesta POST. Per il percorso users, è stato utile
definire le nostre chiavi, poiché ogni utente ha un nome utente univoco. Tuttavia, quando gli utenti aggiungono post del blog all'
app, utilizzeremo una richiesta POST per generare automaticamente una chiave per ogni post del blog:
curl -X POST -d '{
"author": "alanisawesome",
"title": "The Turing Machine"
}' 'https://docs-examples.firebaseio.com/fireblog/posts.json'
Il nostro percorso posts ora contiene i seguenti dati:
{
"posts": {
"-JSOpn9ZC54A4P4RoqVa": {
"author": "alanisawesome",
"title": "The Turing Machine"
}
}
}
Tieni presente che la chiave -JSOpn9ZC54A4P4RoqVa è stata generata automaticamente perché
abbiamo utilizzato una richiesta POST. Una richiesta riuscita sarà indicata da un codice di stato 200 OK
HTTP e la risposta conterrà la chiave dei nuovi dati aggiunti:
{"name":"-JSOpn9ZC54A4P4RoqVa"}Rimozione dei dati
Per rimuovere i dati dal database, possiamo inviare una richiesta DELETE con l'
URL del percorso da cui vogliamo eliminare i dati. Il seguente comando eliminerà Alan dal nostro
users percorso:
curl -X DELETE \ 'https://docs-examples.firebaseio.com/fireblog/users/alanisawesome.json'
Una richiesta DELETE riuscita sarà indicata da un codice di stato HTTP 200 OK con una risposta contenente JSON null.
Parametri URI
L'API REST accetta i seguenti parametri URI durante la scrittura dei dati nel database:
autorizzazione
Il parametro di richiesta auth consente l'accesso ai dati protetti da
Firebase Realtime Database Security Rules ed è
supportato da tutti i tipi di richiesta. L'argomento può essere il segreto dell'app Firebase o un
token di autenticazione, che tratteremo nella sezione relativa all'autorizzazione dell'utente. Nell'esempio seguente inviamo una richiesta POST con un parametro
auth, dove CREDENTIAL è il segreto dell'app Firebase o
un token di autenticazione:
curl -X POST -d '{"Authenticated POST request"}' \
'https://docs-examples.firebaseio.com/auth-example.json?auth=CREDENTIAL'
stampa
Il parametro print ci consente di specificare il formato della risposta del
database. Se aggiungiamo print=pretty alla nostra richiesta, i dati verranno restituiti in un
formato leggibile. print=pretty è supportato dalle richieste GET,
PUT, POST, PATCH e DELETE.
Per sopprimere l'output del server durante la scrittura dei dati, possiamo aggiungere
print=silent alla nostra richiesta. La risposta risultante sarà vuota e indicata da
un 204 No Content codice di stato HTTP se la richiesta va a buon fine.
Il print=silent è supportato dalle richieste GET, PUT,
POST e PATCH.
Scrittura dei valori del server
I valori del server possono essere scritti in una posizione utilizzando un valore segnaposto, ovvero un oggetto con una
singola ".sv" chiave. Il valore di questa chiave è il tipo di valore del server che vogliamo impostare.
Ad esempio, per impostare un timestamp quando viene creato un utente, possiamo procedere nel seguente modo:
curl -X PUT -d '{".sv": "timestamp"}' \
'https://docs-examples.firebaseio.com/alanisawesome/createdAt.json'
"timestamp" è l'unico valore del server supportato ed è il tempo trascorso dall'epoca di UNIX
in millisecondi.
Miglioramento delle prestazioni di scrittura
Se scriviamo grandi quantità di dati nel database, possiamo utilizzare il
print=silent parametro per migliorare le prestazioni di scrittura e ridurre l'utilizzo della larghezza di banda. Nel comportamento di scrittura normale, il server risponde con i dati JSON scritti.
Quando viene specificato print=silent, il server chiude immediatamente la connessione una volta ricevuti i dati, riducendo l'utilizzo della larghezza di banda.
Nei casi in cui effettuiamo molte richieste al database, possiamo riutilizzare la connessione HTTPS
inviando una richiesta Keep-Alive nell'intestazione HTTP.
Condizioni di errore
L'API REST restituirà codici di errore nelle seguenti circostanze:
| Codici di stato HTTP | |
|---|---|
| 400 Richiesta errata |
Una delle seguenti condizioni di errore:
|
| 401 Non autorizzato |
Una delle seguenti condizioni di errore:
|
| 404 Non trovato | Il database Firebase specificato non è stato trovato. |
| 500 Errore interno del server | Il server ha restituito un errore. Per ulteriori dettagli, consulta il messaggio di errore. |
| 503 Servizio non disponibile | Il database Firebase Realtime specificato non è temporaneamente disponibile, il che significa che la richiesta non è stata tentata. |
Protezione dei dati
Firebase ha un linguaggio di sicurezza che ci consente di definire quali utenti hanno accesso in lettura e scrittura a diversi nodi dei nostri dati. Per saperne di più, consulta Realtime Database Security Rules.
Ora che abbiamo trattato il salvataggio dei dati, nella prossima sezione possiamo scoprire come recuperare i dati dal database Firebase tramite l'API REST.