Comprendi le regole di sicurezza di Firebase per l'archiviazione nel cloud

Tradizionalmente, la sicurezza è stata una delle parti più complesse dello sviluppo delle 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 fondamentali per il successo del prodotto.

Analogamente a 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 limitino le richieste di Cloud Storage a un determinato utente o limitino le dimensioni di un caricamento.

Il database in tempo reale di Firebase ha una funzionalità simile, chiamata Regole di sicurezza del database in tempo reale di Firebase

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 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 per singolo utente. Puoi saperne di più nella sezione Autenticazione .

Autorizzazione

Identificare l'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 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 di Cloud Storage predefinite richiedono l'autenticazione Firebase per eseguire qualsiasi operazione 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 di 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.

  • Ulteriori informazioni sulla protezione dei dati utilizzando le regole di sicurezza.