概述
为了实现在不同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注册如下:
<provider android:name=".MyProvider"
android:authorities="com.android.myprovider" />
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;
}
}
网友评论