Comprendere le regole di sicurezza Firebase per Cloud Storage

Tradizionalmente, la sicurezza è stata una delle parti più complesse dello sviluppo di app. Nella maggior parte delle applicazioni, gli sviluppatori devono creare ed eseguire un server che gestisca l'autenticazione (chi è un utente) e l'autorizzazione (cosa può fare un utente). L'autenticazione e l'autorizzazione sono difficili da configurare, più difficili da ottenere correttamente e sono fondamentali per il successo del tuo prodotto.

Proprio come Firebase Authentication semplifica l'autenticazione degli utenti, Firebase Security Rules for Cloud Storage semplifica l'autorizzazione degli utenti e la convalida delle richieste. Le regole di sicurezza di Cloud Storage gestiscono la complessità per te consentendoti di specificare autorizzazioni basate sul percorso. In poche righe di codice puoi scrivere regole di autorizzazione che limitano le richieste di Cloud Storage a un determinato utente o limitano la dimensione di un caricamento.

Il Firebase Realtime Database ha una funzionalità simile, chiamata Firebase Realtime Database Security Rules

Autenticazione

Sapere chi sono i tuoi utenti è una parte importante della creazione di un'applicazione e Firebase Authentication fornisce una soluzione di autenticazione facile da usare, sicura e solo lato client. Le regole di sicurezza Firebase per Cloud Storage si collegano all'autenticazione Firebase per la sicurezza basata sull'utente. Quando un utente viene autenticato con Firebase Authentication, la variabile request.auth nelle regole di sicurezza di Cloud Storage diventa un oggetto che contiene l'ID univoco dell'utente ( request.auth.uid ) e tutte le altre informazioni sull'utente nel token ( request.auth.token ) . Quando l'utente non è autenticato, request.auth è null . Ciò consente di controllare in modo sicuro l'accesso ai dati in base al singolo utente. Puoi saperne di più nella sezione Autenticazione .

Autorizzazione

Identificare il tuo utente è solo una parte della sicurezza. Una volta che sai chi sono, hai bisogno di un modo per controllare il loro accesso ai file in Cloud Storage.

Cloud Storage ti consente di specificare le regole di autorizzazione per file e per percorso che risiedono sui nostri server e determinano l'accesso ai file nella tua app. Ad esempio, le regole di sicurezza Cloud Storage predefinite richiedono l'autenticazione Firebase per eseguire operazioni di read o write su tutti i file:

service firebase.storage {
  match /b/{bucket}/o {
    match /{allPaths=**} {
      allow read, write: if request.auth != null;
    }
  }
}

Puoi modificare queste regole selezionando un'app Firebase nella console Firebase e visualizzando la scheda Rules della sezione Archiviazione.

Convalida dei dati

Le regole di sicurezza Firebase per Cloud Storage possono essere utilizzate anche per la convalida dei dati, inclusa la convalida del nome e del percorso del file, nonché delle proprietà dei metadati del file come contentType e size .

service firebase.storage {
  match /b/{bucket}/o {
    match /images/{imageId} {
      // Only allow uploads of any image file that's less than 5MB
      allow write: if request.resource.size < 5 * 1024 * 1024
                   && request.resource.contentType.matches('image/.*');
    }
  }
}

Prossimi passi

  • Inizia a pianificare lo sviluppo delle regole per i tuoi bucket Cloud Storage.

  • Scopri di più sulla protezione dei tuoi dati utilizzando le regole di sicurezza.