Android四大组件之ContentProvider

概述

为了实现在不同App之间共享数据的需求,Android提供了ContentProvider。

ContentProvider使用

ContentProvider是不同App之间进行数据交换的标准API。当一个App需要把自己的数据暴露给其它App使用时,该App可以通过提供ContentProvider来实现。

ContentProvider使用中包含以下内容:

  • 统一资源标识符(URI): 外部进程通过URI找到对应的ContentProvider和相关数据,再进行数据操作。
    例如:content://com.android.myprovider/person/1
    (1) content:// :主题名(Schema),URI的前缀。暴露和访问ContentProvider的协议默认是content://。
    (2) com.android.myprovider :授权信息(Authority):唯一标识符。根据这个信息找到操作哪个ContentProvider。
    (3) person :表名(Path)。指向数据库中的某个表名。当访问不同资源时,该部分是动态改变的。
    (4) 1 :记录(ID)。表中ID为1的记录。若无指定,则返回全部记录。

  • MIME数据类型 :指定某个扩展名的文件用某种应用程序来打开。
    eg: text/html -- >.html文件采用text程序打开。

  • 继承ContentProvider后,需要重写的方法:
    (1) onCreate() :当其它应用通过ContentResolver第一次访问ContentProvider时被调用,负责数据库的创建和更新。
    (2) query() :查询。
    (3) update() :更新。
    (4) insert() :插入。
    (5) delete() :删除。
    (6) getType() :用于返回当前Uri所代表的数据的MIME类型。两种类型:单条记录--> vnd.android.cursor.item/自定义。多条记录-->vnd.android.cursor.dir/自定义.

  • 在AndroidManifest.xml注册如下:


ContentResolver使用

ContentProvider类并不会直接与外部进程交互,而是通过ContentResolver来操作ContentProvider所暴露的数据。

  • getContentResolver(): 获得ContentResolver对象后,可以调用下面的方法来操作数据。
  • query():查询。
  • update():更新。
  • insert():插入。
  • delete():删除。
ContentResolver resolver =  getContentResolver(); 

Uri uri = Uri.parse("content://com.android.providers.test/person"); 
 
Cursor cursor = resolver.query(uri, null, "query_where", null, null); 

ContentObserver使用

观察ContentProvider中的数据变化,并通知数据访问者。

//注册ContentObserver
getContentResolver().registerContentObserver(uri);

//当ContentProvider数据发生变化时,通知该ContentProvider数据的访问者
public class MyContentProvider extends ContentProvider { 
    public Uri insert(Uri uri, ContentValues values) { 
      db.insert("person", "id", values); 
      getContext().getContentResolver().notifyChange(uri, null); 
   } 
}

//解除观察者
 getContentResolver().unregisterContentObserver(uri);

UriMatcher使用

为了确定ContentProvider实际能处理的Uri,以及确定每个方法中Uri参数所操作的数据,Android系统提供了该工具类。

  • addURI(String authority,String path,int code)方法:用于向UriMatcher对象注册Uri。其中authority和path组成一个Uri,code代表该Uri对应的标识码。

  • int match(Uri uri):根据前面注册的Uri来判断指定Uri对应的标识码。如果找不到匹配的标识码,返回-1。

    //初始化UriMatcher对象
    //常量UriMatcher.NO_MATCH  = 不匹配任何路径的返回码
    UriMatcher matcher = new UriMatcher(UriMatcher.NO_MATCH); 

    //在ContentProvider 中注册URI
    int URI_CODE_1 = 1;
    int URI_CODE_2 = 2;
    matcher.addURI("com.android.myprovider", "person1", URI_CODE_1); 
    matcher.addURI("com.android.myprovider", "person2", URI_CODE_2); 

@Override   
    public String getType(Uri uri) {   
      Uri uri = Uri.parse(" content://com.android.myprovider/person1");   

      switch(matcher.match(uri)){   
        case URI_CODE_1:   
          return tablePerson1;   
        case URI_CODE_2:   
          return tablePerson2;
    }   
}

你可能感兴趣的:(Android四大组件之ContentProvider)