Abilitare la sincronizzazione offline per l'app per dispositivi mobili Xamarin.Android
Panoramica
Questa esercitazione descrive la funzionalità di sincronizzazione offline di App per dispositivi mobili di Azure per Xamarin.Android. La sincronizzazione offline consente agli utenti finali di interagire con un'app, visualizzando, aggiungendo e modificando i dati, anche se non è disponibile una connessione di rete. Le modifiche vengono archiviate in un database locale. Quando il dispositivo torna online, vengono sincronizzate con il servizio remoto.
In questa esercitazione viene aggiornato il progetto client creato nell'esercitazione Creare un'app Xamarin Android per supportare le funzionalità offline di App per dispositivi mobili di Azure. Se non si usa il progetto server di avvio rapido scaricato, è necessario aggiungere al progetto il pacchetto di estensione per l'accesso ai dati. Per altre informazioni sui pacchetti di estensione server, vedere l'articolo Usare l'SDK del server back-end .NET per App per dispositivi mobili di Azure.
Per altre informazioni sulla funzionalità di sincronizzazione offline, vedere l'argomento Sincronizzazione di dati offline nelle app per dispositivi mobili di Azure.
Aggiornare l'app client per supportare le funzionalità offline
Le funzionalità offline delle app per dispositivi mobili di Azure consentono di interagire con un database locale in uno scenario offline. Per usare queste funzionalità nell'app, inizializzare SyncContext in un archivio locale. Fare riferimento alla tabella tramite l'interfaccia di IMobileServiceSyncTable. SQLite viene usato come archivio locale nel dispositivo.
- In Visual Studio aprire Gestione pacchetti NuGet nel progetto completato nell'esercitazione Creare un'app per Xamarin.Android. Cercare e installare il pacchetto NuGet Microsoft.Azure.Mobile.Client.SQLiteStore.
- Aprire il file ToDoActivity.cs e rimuovere i simboli di commendo dalla definizione
#define OFFLINE_SYNC_ENABLED
. - In Visual Studio premere F5 per ricompilare ed eseguire l'app client. L'app funziona come prima di aver abilitato la sincronizzazione offline. Tuttavia, il database locale viene ora popolato con dati che possono essere usati in uno scenario offline.
Aggiornare l'app per disconnetterla dal back-end
In questa sezione verrà interrotta la connessione al back-end dell'app per dispositivi mobili per simulare una situazione offline. Quando si aggiungono elementi di dati, il gestore di eccezioni informa che l'app è in modalità offline. In questo stato, nuovi elementi vengono aggiunti all'archivio locale e vengono sincronizzati con il back-end dell'app per dispositivi mobili la prima volta che viene eseguita un'operazione di push in presenza di uno stato di connessione.
Modificare il file ToDoActivity.cs nel progetto condiviso. Modificare il valore applicationURL in modo che faccia riferimento a un URL non valido:
const string applicationURL = @"https://your-service.azurewebsites.fail";
È anche possibile illustrare il comportamento offline disabilitando le reti Wi-Fi e cellulare sul dispositivo o impostando la modalità aereo.
Premere F5 per compilare ed eseguire l'app. Si noti l'errore di sincronizzazione al momento dell'aggiornamento quando l'app viene avviata.
Immettere nuovi elementi. Si noti che il push ha esito negativo con stato [CancelledByNetworkError] ogni volta che si fa clic su Salva. I nuovi elementi todo, tuttavia, sono presenti nell'archivio locale fino a quando non è possibile effettuarne il push al back-end dell'app per dispositivi mobili. In un'app di produzione, se si eliminano queste eccezioni, l'app client si comporta come se fosse ancora connessa al back-end dell'app per dispositivi mobili.
Chiudere l'app e riavviarla per verificare che i nuovi elementi creati siano salvati in modo permanente nell'archivio locale.
(Facoltativo) In Visual Studio aprire Esplora server. Passare al database in Database SQL>Azure. Fare clic con il pulsante destro del mouse sul database e scegliere Apri in Esplora oggetti di SQL Server. È ora possibile passare alla tabella di database SQL e al relativo contenuto. Verificare che i dati nel database back-end non siano stati modificati.
(Facoltativo) Usare uno strumento REST come Fiddler o Postman per eseguire una query sul back-end mobile, usando una query GET nel formato
https://<your-mobile-app-backend-name>.azurewebsites.net/tables/TodoItem
.
Aggiornare l'app per la riconnessione al back-end dell'app per dispositivi mobili
In questa sezione viene effettuata la riconnessione dell'app al back-end dell'app per dispositivi mobili. Alla prima esecuzione dell'applicazione, il gestore eventi OnCreate
chiama OnRefreshItemsSelected
. Questo metodo chiama SyncAsync
per sincronizzare l'archivio locale con il database back-end.
Aprire il file ToDoActivity.cs nel progetto condiviso e annullare la modifica della proprietà applicationURL.
Premere F5 per ricompilare ed eseguire l'app. L'app sincronizza le modifiche locali con il back-end dell'app per dispositivi mobili di Azure usando operazioni push e pull quando viene eseguito il metodo
OnRefreshItemsSelected
.(Facoltativo) Visualizzare i dati aggiornati usando Esplora oggetti di SQL Server o uno strumento REST come Fiddler. Si noti che i dati sono stati sincronizzati tra il database back-end dell'app per dispositivi mobili di Azure e l'archivio locale.
Nell'app fare clic sulla casella di controllo accanto ad alcuni elementi da completare nell'archivio locale.
CheckItem
chiamaSyncAsync
per sincronizzare ogni elemento completato con il back-end dell'app per dispositivi mobili.SyncAsync
chiama operazioni sia push che pull. Ogni volta che si esegue il pull su una tabella a cui il client ha apportato modifiche, viene sempre effettuato automaticamente il push. Ciò assicura che tutte le tabelle nell'archivio locale e le relazioni restino coerenti e può determinare un'operazione push non prevista. Per altre informazioni su questo comportamento, vedere Sincronizzazione di dati offline nelle app per dispositivi mobili di Azure.
Verificare il codice di sincronizzazione del client
Il progetto client Xamarin scaricato dopo aver completato l'esercitazione Creare un'app Xamarin Android contiene già il codice che supporta la sincronizzazione offline mediante un database SQLite locale. Ecco un breve riepilogo degli elementi già inclusi nel codice dell'esercitazione. Per una panoramica concettuale della funzionalità, vedere Sincronizzazione di dati offline nelle app per dispositivi mobili di Azure.
Prima di poter eseguire qualsiasi operazione su tabella, è necessario inizializzare l'archivio locale. Il database di archiviazione locale viene inizializzato quando
ToDoActivity.OnCreate()
esegueToDoActivity.InitLocalStoreAsync()
. Questo metodo comporta la creazione di un database SQLite locale usando la classeMobileServiceSQLiteStore
fornita dall'SDK del client delle app per dispositivi mobili di Azure.Il metodo
DefineTable
crea nell'archivio locale una tabella corrispondente ai campi del tipo specificato,ToDoItem
in questo caso. Il tipo non deve necessariamente includere tutte le colonne presenti nel database remoto. È possibile archiviare solo un subset di colonne.// ToDoActivity.cs private async Task InitLocalStoreAsync() { // new code to initialize the SQLite store string path = Path.Combine(System.Environment .GetFolderPath(System.Environment.SpecialFolder.Personal), localDbFilename); if (!File.Exists(path)) { File.Create(path).Dispose(); } var store = new MobileServiceSQLiteStore(path); store.DefineTable<ToDoItem>(); // Uses the default conflict handler, which fails on conflict // To use a different conflict handler, pass a parameter to InitializeAsync. // For more details, see https://go.microsoft.com/fwlink/?LinkId=521416. await client.SyncContext.InitializeAsync(store); }
Il membro
toDoTable
diToDoActivity
è di tipoIMobileServiceSyncTable
invece cheIMobileServiceTable
. IMobileServiceSyncTable indirizza tutte le operazioni di creazione, lettura, aggiornamento ed eliminazione (CRUD, Create, Read, Update, Delete) sulle tabelle al database di archiviazione locale.Decidere quando viene eseguito il push delle modifiche al back-end delle app per dispositivi mobili di Azure chiamando
IMobileServiceSyncContext.PushAsync()
. Il contesto di sincronizzazione aiuta a mantenere le relazioni tra tabelle rilevando le modifiche apportate da un'app client in tutte le tabelle ed eseguendone il push quando viene chiamatoPushAsync
.Il codice fornito chiama
ToDoActivity.SyncAsync()
per eseguire la sincronizzazione ogni volta che l'elenco todoitem viene aggiornato o un oggetto todoitem viene aggiunto o completato. Il codice viene sincronizzato dopo ogni modifica locale.Nel codice fornito viene eseguita una query su tutti i record presenti nella tabella
TodoItem
remota, ma è anche possibile filtrare i record passando un ID di query e una query aPushAsync
. Per altre informazioni, vedere la sezione Sincronizzazione incrementale in Sincronizzazione sincronizzazione dati in App per dispositivi mobili di Azure.// ToDoActivity.cs private async Task SyncAsync() { try { await client.SyncContext.PushAsync(); await toDoTable.PullAsync("allTodoItems", toDoTable.CreateQuery()); // query ID is used for incremental sync } catch (Java.Net.MalformedURLException) { CreateAndShowDialog (new Exception ("There was an error creating the Mobile Service. Verify the URL"), "Error"); } catch (Exception e) { CreateAndShowDialog (e, "Error"); } }