Android 如何处理REST调用、数据持久性、同步和观察ContentProvider

Android 如何处理REST调用、数据持久性、同步和观察ContentProvider,android,rest,android-contentprovider,android-syncadapter,contentobserver,Android,Rest,Android Contentprovider,Android Syncadapter,Contentobserver,我知道这个问题已经被问了太多次了,但我认为我试图针对的问题有点不同,可能更复杂 我将开发一个使用RESTful Web服务的应用程序,它需要满足以下要求: 该应用程序应该在列表和详细信息中显示一些书籍、作者和编辑 该应用程序还应该允许搜索一本书 书籍、作者和编辑从RESTful web服务获取 每个实体都必须被缓存,这样当我打开一个活动时,我会首先看到旧数据(如果有的话),而新数据会从网络中更新 每次实体更新时,都应通知相关方(ContentObserver?定期的监听器实现?) 如果调用已经

我知道这个问题已经被问了太多次了,但我认为我试图针对的问题有点不同,可能更复杂

我将开发一个使用RESTful Web服务的应用程序,它需要满足以下要求:

  • 该应用程序应该在列表和详细信息中显示一些书籍、作者和编辑

  • 该应用程序还应该允许搜索一本书

  • 书籍、作者和编辑从RESTful web服务获取

  • 每个实体都必须被缓存,这样当我打开一个活动时,我会首先看到旧数据(如果有的话),而新数据会从网络中更新

  • 每次实体更新时,都应通知相关方(
    ContentObserver
    ?定期的
    监听器
    实现?)

  • 如果调用已经在执行(比如对
    api/books/1337
    或对
    api/editors
    ),则应通知调用方它正在加载数据,并应将旧的数据(如果存在)提供给调用方,就像它是原始调用方一样

  • 某些数据(仅书籍和作者)应每N分钟更新一次(由用户决定),并应通知观察者(
    SyncAdapter
    ?)

问题:

在观看和研究了所有组件之后,我的疑问如下:

  • 如何透明地处理任何调用方的“实体正在更新””概念?我是否应该在必须实现的
    ContentProvider
    上使用
    ContentObserver

  • 如果我使用
    ContentObserver
    我可以很容易地为单个实体设置一个状态标志(如Dobjanschi所建议的),例如
    更新
    插入
    ,等等。但我该如何处理这个列表呢?假设我想要一个图书列表,我应该把状态标志放在哪里?我是否应该将其放在状态表中,仅用于列表?如果是这样,我应该观察两个
    游标,一个用于状态,一个用于实际列表(即表/内容URI)。如果我请求的实体不存在(尚未存在),或者REST调用返回一个
    404
    ,该怎么办?我如何处理回拨

  • 如果我将所有REST方法放在
    **SyncAdapter**
    中,我是否可以“强制”
    SyncAdapter
    从网络更新实体/实体列表(并因此将其放入适当的表中)?这样,状态标志将非常有用

  • SyncAdapter
    能否处理多个实体(实际上,实体列表,因为我想时不时地更新书籍和编辑器),因为它只有
    performSync
    方法

  • 如果用户在设备设置中禁用了我的
    SyncAdapter
    实现,则不会更新任何内容(这很好)。但是,如果用户在活动中单击“更新书籍”按钮,我仍然可以调用
    performSync
    方法,还是将其禁用


  • SyncAdapter是一种涉及五个组件的设计模式:

  • 应用程序。这使用了一组
    活动
    以及
    光标
    内容观察者
    ,还可能使用
    光标或适配器
    ,以及一些活动来为来自
    内容提供者的本地存储数据提供UI
  • ContentProvider
    本地设备的数据存储。处理CRUD调用,处理通知
    SyncAdapter
    需要将更新推送到服务器的问题
  • 帐户
    远程服务器上的用户标识
  • SyncAdapter
    一个后台进程,它运行并保持本地数据存储与服务器同步
  • 服务器本身
  • 所以。对这些问题:

  • “正在更新”表示“具有尚未推送到服务器的本地更改。这是您在数据库中的某一行上设置的标志。它在创建/更新/删除行时在ContentProvider中设置。当SyncAdapter运行时,它会看到该标志,将更新推送到服务器,清除该标志。该标志本身有两个功能:
    a.告诉用户应用程序正在忙着保存更改,以及保存完成的时间。
    b.将行标记为已更改,以便SyncAdapter知道将其推送到服务器。
    更多细节

  • 如果您没有同步整个目录,则客户端将直接查询服务器并通过将结果放入ContentProvider来缓存结果。那里没有状态标志,因为它们来自服务器,因此与服务器状态匹配。编写SyncAdapter以忽略它们,或者在删除它们后丢弃它们n缓存了几天

  • a.为了确保本地更新被发送到服务器,您可以编写ContentProvider,在ContentProvider的创建/更新/删除调用期间通知SyncAdapter。
    b.为了确保定期从服务器获取更新,您可以将帐户配置为自动同步

  • 是的。performSync只是一个函数调用。编写它以执行您想要的操作。让它从服务器获取表1并将其放入ContentProvider中的一个表中。然后让它获取表2,并将其放入另一个表中。等等

  • a.您可以通过调用附加包中的
    ContentResolver.RequestSync()
    ContentResolver.sync\u EXTRAS\u MANUAL
    来强制同步。
    b.您可以手动获取带有客户端代码的内容,并直接将其推送到ContentProvider中

  • 如果您查看中的部分,您将发现有关如何:


  • 非常感谢您宝贵的回答。我仍然没有正确地列出列表:假设用户单击“更新”按钮。W