La gestione dei dati degli utenti in Capacitor richiede un archiviazione sicura, politiche di conservazione chiare e conformità con le leggi di protezione dei dati come GDPR e CCPA. Questa guida spiega come minimizzare la raccolta di dati, proteggere informazioni sensibili e gestire efficacemente le autorizzazioni. Ecco un breve riassunto:
- Minimizzazione dei dati: Raccogli solo ciò che è necessario per le funzionalità specifiche degli app.
- Archiviazione sicura: Utilizza strumenti come il
@capacitor/secure-storageplugin per l'encryption. - Dati di conservazione: Automatizza la cancellazione in base a limiti di tempo definiti.
- Diritti dell'utente: Abilita gli utenti ad accedere, cancellare o esportare i propri dati.
- Gestione delle autorizzazioni: Richiedi autorizzazioni contestualmente e fornisce alternative per le richieste negate.
- Aggiornamenti OTA: Assicurati di aggiornamenti sicuri in rete con strumenti come Capgo.
Come utilizzare Ionic Capacitor Memorizzazione Sicura

Riduzione della Raccolta di Dati
La raccolta di dati strutturata è fondamentale per rimanere conformi alle normative sulla privacy. Utilizzando gli strumenti integrati di Capacitor per minimizzare la raccolta di dati, puoi intraprendere passaggi pratici per migliorare le pratiche di dati del tuo app.
Recensione della Raccolta di Dati
Inizia mappando come i dati scorrono attraverso il tuo app. Utilizza strumenti come visualizzatori di linea dei dati per individuare aree in cui potrebbe essere raccolto dati non necessari. Il software di valutazione dell'impatto sulla privacy (PIA) può guidarti nell'assessare se ogni pezzo di dati è veramente necessario. Ecco una suddivisione delle aree da concentrare:
| Tipo di Dati | Focalizzazione della Recensione | Elementi da Eseguire |
|---|---|---|
| Input dell'Utente | Campi di formazione e validazione | Elimina i campi non necessari |
| API Chiamate | Payload delle richieste/risposte | Filtra i campi di dati aggiuntivi |
| Storage | Dati memorizzati e persistenti | Optimizza l'uso dello storage |
| Analisi | Tracciamento dell'uso | Conserva solo le metriche essenziali |
Obiettivi di raccolta dati
Assicurati di essere chiaro sul motivo per cui stai raccogliendo ogni pezzo di dati. Ogni punto di dati dovrebbe servire a un fine specifico. Ad esempio:
// Purpose-driven data collection example
const userPreferences = {
location: "Used for local weather updates",
notification: "Needed for sending alerts"
};
Se la tua app ha una funzione del tempo, potrebbe richiedere solo un codice code invece di un indirizzo completo. Questo approccio assicura di raccogliere solo le informazioni necessarie per le funzioni di base dell'app[1][5].
Controlli di Inserimento Dati
Utilizza strumenti di validazione per limitare la quantità di dati raccolti attraverso i moduli e API chiamate. Combina la validazione client-side con la verifica server-side per applicare questi limiti in modo efficace.
Incorpora le funzionalità di sicurezza di Capacitor per migliorare questi controlli:
- Utilizza menu a discesa al posto di campi di testo libero dove possibile.
- Stabilisci limiti di caratteri per i campi di input di testo.
Pianifica audit trimestrali con strumenti di scoperta automatizzati per assicurarti che le tue pratiche di raccolta dati rimangano efficienti e allineate con la funzionalità dell'app prevista.
Sicurezza e Archiviazione dei Dati
Una volta definiti i tuoi confini di raccolta dati, è cruciale implementare misure per proteggere le informazioni degli utenti mentre si aderisce ai principi di minimizzazione dei dati.
Configurazione di Archiviazione Sicura
The @capacitor/secure-storage il plugin utilizza funzionalità di sicurezza integrate come iOS Keychain e Android Keystore per proteggere i dati sensibili [1].
import { SecureStorage } from '@capacitor/secure-storage';
// Store sensitive data
await SecureStorage.set({
key: 'authToken',
value: 'user-specific-token'
});
// Retrieve stored data
const { value } = await SecureStorage.get({ key: 'authToken' });
Metodi di crittografia dei dati
Aggiungere la crittografia client-side è un altro strato di protezione. Le librerie come CryptoJS possono aiutare a crittografare informazioni sensibili:
// Basic encryption/decryption implementation
const encryptData = (data: string, key: string): string => {
return CryptoJS.AES.encrypt(data, key).toString();
};
Rimuovere regolarmente le chiavi di crittografia è una buona pratica per migliorare la sicurezza. Ciò assicura che anche se una chiave è compromessa, il resto dei dati rimane sicuro [2].
Confronto delle opzioni di archiviazione
Scegliere la soluzione di archiviazione giusta dipende dalla sensibilità dei dati. Ecco un confronto rapido:
| Caratteristica | Archiviazione sicura | Archiviazione locale |
|---|---|---|
| Nivello di sicurezza | Alto (crittografato) | Base |
| Migliore per | Token, password | Impostazioni non sensibili |
| Performance | Più lento (a causa della crittografia) | Accesso più veloce |
Il Storage Sicuro API è una scelta solida per l'archiviazione di informazioni critiche come i token di autenticazione e i dati utente personali [1][4]. I suo capacità di crittografia si allineano anche con le politiche di conservazione, consentendo un accesso controllato ai dati entro i tempi specificati [2].
sbb-itb-f9944d2
Limiti di archiviazione dei dati
Impostare politiche di conservazione dei dati aiuta a conformarsi ai principi di minimizzazione dei dati, assicurandosi che le informazioni non siano conservate più a lungo del necessario.
Regole di archiviazione dei dati
I diversi tipi di dati degli utenti dovrebbero avere periodi di conservazione definiti in base al loro scopo e livello di sensibilità. Di seguito è riportato un framework suggerito per la gestione della conservazione dei dati in Capacitor:
| Tipo di dati | Periodo di conservazione | Giustificazione |
|---|---|---|
| Dati di account | Fino alla cancellazione dell'account o 2 anni di inattività | Necessari per le operazioni relative all'account |
| Registri di Transazione | 7 anni | Conformità alle normative finanziarie |
| Dati di Analisi | 90 giorni (anonimizzati), 1 anno (cancellazione) | Supporta miglioramenti delle funzionalità |
| Preferenze di Marketing | Fino all'opt-out o alla cancellazione del conto | Aderisce alle richieste di consenso |
Ecco un esempio di come memorizzare dati con una data di scadenza in modo programmatico:
async function storeDataWithExpiration(key: string, value: any, retentionDays: number) {
const item = {
value: value,
expiration: Date.now() + (retentionDays * 24 * 60 * 60 * 1000)
};
await Preferences.set({ key, value: JSON.stringify(item) });
}
Rimozione automatica dei dati
Capacitor's background fetch feature è una utile risorsa per automatizzare la pulizia dei dati e ridurre l'intervento manuale.
import { BackgroundFetch } from '@capacitor/background-fetch';
BackgroundFetch.registerTask({
taskId: 'data-cleanup',
delay: 3600000,
periodic: true,
requiresNetworkConnectivity: false
}, async () => {
await cleanExpiredData();
return BackgroundFetch.Result.NewData;
});
Se stai utilizzando SQLite per il storage, puoi configurare i trigger per eliminare automaticamente i record scaduti:
CREATE TRIGGER remove_expired_data
AFTER INSERT ON user_data
BEGIN
DELETE FROM user_data
WHERE expiration_date < CURRENT_TIMESTAMP;
END;
Opzioni di rimozione dei dati degli utenti
Fornire agli utenti strumenti per gestire i propri dati è essenziale. Ecco due funzionalità chiave che puoi implementare:
- Elimina dati specifici: Consentire agli utenti di eliminare determinati tipi di dati legati alla loro account.
async function deleteSpecificData(userId: string, dataType: string) {
await Preferences.remove({ key: `${userId}_${dataType}` });
if (db) {
await db.run(
'DELETE FROM user_data WHERE user_id = ? AND data_type = ?',
[userId, dataType]
);
}
}
- Esporta dati degli utenti: Abilita gli utenti a scaricare i propri dati archiviati in un formato strutturato.
async function exportUserData(userId: string) {
// Gathers all user data for export
const userData = await collectUserData(userId);
return JSON.stringify(userData);
}
L'autorità francese di protezione dei dati CNIL sottolinea che i periodi di conservazione devono essere allineati con la funzionalità principale dell'app [3]. Questo principio è particolarmente rilevante per gli sviluppatori di app Capacitor e dovrebbe guidare la tua strategia di conservazione dei dati.
Controllo delle autorizzazioni dell'app
Gestire le autorizzazioni dell'app con cura è fondamentale per tutelare i dati degli utenti e garantire che l'app funzioni come previsto. Gestendo le autorizzazioni in modo appropriato, puoi limitare l'accesso solo alle funzionalità del dispositivo che la tua app veramente necessita. Capacitor’s Permissions API offre un approccio unificato per la gestione delle autorizzazioni su entrambi iOS e Android.
Passaggi per la richiesta di autorizzazioni
Assicurati che le autorizzazioni richieste siano in linea con gli obiettivi di raccolta dei dati dell'app. Ecco un esempio di implementazione per la gestione delle richieste di autorizzazione in un'app Capacitor:
import { Permissions } from '@capacitor/core';
const permissionHandler = async (permissionType: string) => {
const status = await Permissions.query({ name: permissionType });
if (status.state === 'granted') {
return true;
}
const shouldProceed = await showExplanationDialog(
`We need ${permissionType} access to provide core functionality`
);
if (shouldProceed) {
const result = await Permissions.request({ name: permissionType });
return result.state === 'granted';
}
return false;
};
Gestione delle autorizzazioni negate
Se un utente rifiuta una richiesta di autorizzazione, fornisce alternative e indicazioni chiare. Ecco un esempio:
const handleDeniedPermission = async (permissionType: string) => {
const status = await Permissions.query({ name: permissionType });
if (status.state === 'denied') {
const alternatives = {
camera: 'manual photo upload',
location: 'manual address entry',
notifications: 'in-app message center'
};
showAlternativeFeature(alternatives[permissionType]);
if (status.canOpenSettings) {
offerSettingsRedirect();
}
}
};
Richiesta di autorizzazioni nel momento giusto
Quando chiedi le autorizzazioni conta. Una strategia di timing può migliorare significativamente le tassi di accettazione degli utenti. Ecco un breve riassunto delle strategie di timing:
| Strategia di timing | Miglior utilizzo |
|---|---|
| Just-in-Time | For specifiche funzionalità quando necessario |
| Contestuale | For funzionalità non critiche |
| Primo Avvio | For funzionalità di base richieste in anticipo |
| Ritardato | For funzionalità facoltative in un momento successivo del percorso dell'utente |
Esempio: puoi richiedere l'accesso alla fotocamera solo quando l'utente inizia un'azione come scattare una foto:
const captureImage = async () => {
const userStartedCapture = true;
if (userStartedCapture) {
const granted = await permissionHandler('camera');
if (granted) {
await startCamera();
} else {
showUploadOption();
}
}
};
Il richiesta contestuale di questo tipo può aumentare le tassi di accettazione del 50% rispetto alle richieste in anticipo [2]. Per garantire un'esperienza fluida, mantieni uno stato di tracciamento delle autorizzazioni che salva le decisioni dell'utente tra le sessioni.
Una volta gestite le autorizzazioni, puoi spostare l'attenzione sulla sicurezza degli aggiornamenti, soprattutto per i deployment OTA (Over-The-Air).
Sicurezza Aggiornamento OTA
Per garantire l'integrità dei dati durante gli aggiornamenti dell'applicazione, è fondamentale utilizzare processi di aggiornamento OTA (Over-The-Air) sicuri. Questi aggiornamenti aiutano a prevenire modifiche non autorizzate all'app __CAPGO_KEEP_0__, che altrimenti potrebbero bypassare i limiti sulla raccolta dei dati. Firma Pacchetti AggiornamentoLa firma dei pacchetti di aggiornamento è un passo critico per proteggersi contro modifiche non autorizzate all'app code. Ecco alcune misure chiave per assicurare l'aggiornamento OTA sicuro:
Misura di Sicurezza
Signing update packages is a critical step in protecting against unauthorized code changes. Here are some key measures to secure OTA updates:
| Protezione dei Contenuti | Crittografia AES |
|---|---|
| Sicurezza di Spedizione | HTTPS con pinning del certificato |
| Integrità dell'Aggiornamento | Security Measure |
| How It’s Done | Verifica del hash |
| Sicurezza della versione | Numero di versione firmato |
| Recupero in caso di fallimento | Capacità di rollback istantaneo |
Capgo Sistema di aggiornamento

Capgo semplifica gli aggiornamenti OTA sicuri per le Capacitor app offrendo funzionalità di sicurezza automatizzate. Ecco un esempio di come utilizzare il sistema di aggiornamento di Capgo nella tua app:
import { CapacitorUpdater } from '@capgo/capacitor-updater';
const secureUpdate = async () => {
try {
const update = await CapacitorUpdater.download({
version: 'latest',
validateSignature: true
});
if (update.status === 'success') {
await CapacitorUpdater.set(update);
}
} catch (error) {
await CapacitorUpdater.rollback();
}
};
Questa approccio garantisce che gli aggiornamenti siano validati e sicuri, con opzioni di rollback in caso di fallimento.
Conformità alla politica dello store
Seguire le linee guida degli store per gli aggiornamenti OTA è necessario[1][6][7]Ogni piattaforma ha specifiche richieste per garantire che gli aggiornamenti siano in linea con le loro politiche di conservazione dei dati e di sicurezza:
| Piattaforma | Richieste di conformità |
|---|---|
| iOS | Solo aggiornamenti JavaScript o di asset |
| Android | Deve essere ottenuta la consapevolezza dell'utente |
| Entrambi | Verifiche di sicurezza e documentazione adeguata |
Di seguito è riportato un esempio di implementazione di aggiornamenti conformi allo store:
const compliantUpdate = async () => {
const userConsent = await requestUpdateConsent();
if (userConsent) {
await CapacitorUpdater.setUpdateConfig({
type: 'assets-only',
scope: 'ui-updates' // Updates limited to UI components
});
}
};
const preventDowngrade = async (newVersion, currentVersion) => {
const versions = await CapacitorUpdater.getVersions();
if (versions.current.buildNumber > newVersion.buildNumber) {
throw new Error('Downgrade attempt detected');
}
};
Riepilogo
Punti chiave da ricordare
Handling user data effectively involves combining these core strategies:
- Raccogliere solo i dati necessari.
- Utilizzare la crittografia nativa del piattaforma per proteggerli.
- Automatizzare i termini di conservazione dei dati.
- Configurare controlli di accesso dettagliati.
Questi passaggi lavorano insieme per garantire la conformità dal momento in cui i dati vengono raccolti fino a quando non vengono automaticamente eliminati.
Passaggi per l'Implementazione
Per mettere in pratica queste strategie:
- Auditare i flussi di dati utilizzando i metodi discussi nella sezione 2.
- Rafforzare la sicurezza dello storage come descritto nella sezione 3.
- Configurare processi di cancellazione automatici basati sulla sezione 4.
- Stabilire e applicare controlli di accesso dettagliati come descritti nella sezione 5.
Sfruttando Capgo
Per le squadre che gestiscono aggiornamenti OTA, Capgo offre strumenti di sicurezza integrati che si allineano a questi sforzi:
- Crittografia end-to-end per garantire la sicurezza dei pacchetti di aggiornamento.
- Monitoraggio in tempo reale per affrontare rapidamente potenziali minacce alla sicurezza.
Continua da Come gestire i dati degli utenti nelle App Capacitor
Se stai utilizzando Come gestire i dati degli utenti nelle App Capacitor per pianificare la sicurezza e la conformità, connettilo con Crittografia per la descrizione dettagliata di Crittografia, Compliance per la dettagliata implementazione in Compliance, Capgo Scansionatore di Sicurezza per il flusso di lavoro del prodotto in Capgo Scansionatore di Sicurezza, Capgo Sicurezza per il flusso di lavoro del prodotto in Capgo Sicurezza, e Capgo Centro di Trust per il flusso di lavoro del prodotto in Capgo Centro di Trust.