Android モバイル アプリのオフライン同期の有効化

概要

このチュートリアルでは、Android 向け Azure Mobile Apps のオフライン同期機能について説明します。 オフライン同期を使用すると、エンド ユーザーはネットワークにアクセスできなくても、データの表示、追加、変更など、モバイル アプリとやり取りできます。 変更は、ローカル データベースに格納されます。 デバイスが再びオンラインになると、これらの変更がリモート バックエンドと同期されます。

Azure Mobile Apps を初めて使用する場合は、チュートリアル「 Android アプリの作成」を完了しておく必要があります。 ダウンロードしたクイック スタートのサーバー プロジェクトを使用しない場合は、データ アクセス拡張機能パッケージをプロジェクトに追加する必要があります。 サーバーの拡張機能パッケージの詳細については、「 Work with the .NET backend server SDK for Azure Mobile Apps (Azure Mobile Apps 用の .NET バックエンド サーバー SDK を操作する)」を参照してください。

オフラインの同期機能の詳細については、トピック「 Azure Mobile Apps でのオフライン データ同期」をご覧ください。

オフライン同期をサポートするようにアプリケーションを更新する

オフライン同期では、同期テーブルに対して読み取りと書き込みを行います (IMobileServiceSyncTable インターフェイスを使用)。このテーブルは、デバイス上の SQLite データベースの一部です。

デバイスと Azure Mobile Services の間で変更をプッシュしたりプルしたりするには、同期コンテキスト (MobileServiceClient.SyncContext) を使用します。この同期コンテキストは、データをローカルに格納するローカル データベースで初期化されます。

  1. TodoActivity.java で、mToDoTable の既存の定義をコメント アウトし、同期テーブルのバージョンをコメント解除します。

     private MobileServiceSyncTable<ToDoItem> mToDoTable;
    
  2. onCreate メソッドで、mToDoTable の既存の初期化をコメント アウトし、次の定義をコメント解除します。

     mToDoTable = mClient.getSyncTable("ToDoItem", ToDoItem.class);
    
  3. refreshItemsFromTable で、results の定義をコメント アウトし、次の定義をコメント解除します。

     // Offline Sync
     final List<ToDoItem> results = refreshItemsFromMobileServiceTableSyncTable();
    
  4. refreshItemsFromMobileServiceTableの定義をコメント アウトします。

  5. refreshItemsFromMobileServiceTableSyncTableの定義をコメント解除します。

     private List<ToDoItem> refreshItemsFromMobileServiceTableSyncTable() throws ExecutionException, InterruptedException {
         //sync the data
         sync().get();
         Query query = QueryOperations.field("complete").
                 eq(val(false));
         return mToDoTable.read(query).get();
     }
    
  6. syncの定義をコメント解除します。

     private AsyncTask<Void, Void, Void> sync() {
         AsyncTask<Void, Void, Void> task = new AsyncTask<Void, Void, Void>(){
             @Override
             protected Void doInBackground(Void... params) {
                 try {
                     MobileServiceSyncContext syncContext = mClient.getSyncContext();
                     syncContext.push().get();
                     mToDoTable.pull(null).get();
                 } catch (final Exception e) {
                     createAndShowDialogFromTask(e, "Error");
                 }
                 return null;
             }
         };
         return runAsyncTask(task);
     }
    

アプリケーションをテストする

このセクションでは、WiFi をオンにした状態で動作をテストした後、WiFi をオフにしてオフライン状態にするシナリオを使用します。

データ項目を追加したときに、これらの項目はローカルの SQLite ストアに保持されていますが、 [更新] ボタンをクリックするまでモバイル サービスと同期されません。 他のアプリでは、データを同期させるタイミングに関する要件が異なる場合がありますが、このチュートリアルではデモの目的で、ユーザーが明示的にデータ同期を要求したことにします。

そのボタンを押すと、新しいバックグラウンド タスクが開始されます。 タスクは、ローカル ストアに加えられたすべての変更を同期コンテキストを使用してプッシュした後、変更済みのすべてのデータを Azure からローカル テーブルにプルします。

オフライン テスト

  1. デバイスまたはシミュレーターを [ 機内モード] に切り替えます。 これでオフラインのシナリオが準備できます。

  2. いくつかの ToDo 項目を追加 するか、一部の項目を完了としてマークします。 デバイスまたはシミュレーターを終了して (またはアプリケーションを強制的に閉じて)、再起動します。 変更はローカルの SQLite ストアに保持されているため、変更がデバイスに保存されたことを確認します。

  3. SQL Server Management Studio などの SQL ツール、または FiddlerPostman などの REST クライアントを使用して、Azure TodoItem テーブルの内容を表示します。 新しい項目が、サーバーと同期されていないことを確認します。

    + For a Node.js backend, go to the [Azure portal](https://portal.azure.com/), and in your Mobile App backend click **Easy Tables** > **TodoItem** to view the contents of the `TodoItem` table.
    + For a .NET backend, view the table contents either with a SQL tool such as *SQL Server Management Studio*, or a REST client such as *Fiddler* or *Postman*.
    
  4. デバイスまたはシミュレーターの WiFi を有効にします。 次に [ 更新 ] ボタンを押します。

  5. Azure ポータルで、もう一度 TodoItem のデータを参照します。 新しく変更した TodoItems が表示されます。

その他のリソース