实现跨程序共享数据的功能,官方推荐的方式就是使用内容提供器
创建一个类来继承ContentProvider,实现其方法
-
onCreate()
方法:初始化内容提供器的时候调用。通常会在这里完成对数据的创建和升级操作,返回true表示内容提供器初始化成功,返回false则表示失败。只有当存在ContentResolver尝试访问我们程序中的数据时,内容提供器才会被初始化 -
query()
方法:从内容提供器中查询数据。使用uri参数来确定查询哪张表,查询的结果存放在Cursor对象中返回 -
insert()
方法:向内容提供器中添加一条数据,使用uri参数来确定要添加到的表,返回一个用于表示这条新纪录的URI -
update()
方法:更新内容提供器中已有的数据,使用uri参数确定更新哪一张表中的数据,受影响的行数将做为放回值返回 -
delete()
方法:从内容提供器中删除数据,使用uri参数来确定删除哪一张表中的数据,被删除的行数将做为返回值返回 -
getType()
方法:根据传入的内容URI来返回相应的MIME类型
数据共享,只是将不涉及用户隐私的数据或可共享的数据提供外部访问接口,用于第三方应用程序来获取,第三方应用程序是通过uri参数来确定资源的,故我们应将我们共享出来的数据在内容提供器中存放
匹配内容Uri来确定访问的资源
- 存放Uri:添加内容URI格式,
UriMatcher
类提供了一个addURI()
方法,这个方法接收三个参数,可以分别把权限、路径(可以使用通配符 # )和一个自定义代码传进去 - 匹配Uri:调用
UriMatcher()
类的match()
方法,一个Uri对象做为参数传入,会和内容提供器中已经添加进来的Uri格式进行匹配,返回值就是某个能够匹配这个Uri对象所对应的自定义代码
通过返回的自定义代码来执行相应的数据库的CRUD操作
public class MyProvider extends ContentProvider{
//自定义的代码,用于传入的内容Uri匹配内容提供器中的Uri格式做为返回数据
public static final int TABLE_DIR = 0;
public static final int TABLE_ITEM = 1;
private static UriMatcher uriMatcher;
static{
//创建UriMatcher对象
uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
//添加Uri格式
uriMatcher.addURI("com.example.app.provider", "table", TABLE_DIR);
uriMatcher.addURI("com.example.app.provider", "table/#", TABLE_ITEM);
}
@override
public Curcor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder){
switch(uriMatcher.match(uri)){ //根据传入的Uri来匹配内容提供器中的URI格式
case TABLE_DIR:
//查询table表中的所有数据
break;
case TABLE_DIR:
//查询table表中的单条数据
break;
default:
break;
}
}
..........
}
内容提供器是Android四大组件之一
需要在清单文件中注册,在application标签下创建provider标签:
<provider
android:name="<path>"
android:authorities="<authority>"
android:exported="true" >
</provider>
-
<path>
表示:自定义内容提供器的全名 -
<authority>
表示:该内容提供器的权限 -
android:exported="true"
表示:指定为true
,表示该内容提供器可以被其他应用程序访问
保护隐私数据:
所有的 CRUD操作都一定要匹配到相应的内容URI格式才能进行,我们不可能向UriMatcher
中添加隐私数据的URI,所以这部分数据根本无法被外部程序访问到