本文是我各处东拼西凑加上自己实现一个ContentProvider的使用总结,留做后用,主要介绍ContentProvider的集成方法。
一、综述
ContentProvider是Android四大组件之一,其核心功能是提供应用间的统一的数据访问方式,当然也可以用于应用内的数据封装。ContentProvider类似C/S结构,应用A实现ContentProvider向外提供应用内的数据访问,应用B使用Context.getContentResolver()来间接与应用A的Provider交互。
ContentProvider提供一套类似数据库的query/delete/insert/update的方法来操作数据,开发者可以以此来屏蔽管理数据的真正方式 (SharePreference/File/SQLite等)。另外,ContentProvider也提供了直接操作文件的方式(覆写openFile),第三方应用可以通过该方式读写当前应用的私有文件(data/data等)。
二、相关知识
2.1 UriMatcher和ContentUris的使用
UriMatcher主要用户判断Uri是否符合特定格式,用法如下:
private static final int TYPE_ALL = 1;
private static final int TYPE_SINGLE = 2;
private static UriMatcher mUriMatcher = new UriMatcher(UriMatcher.NO_MATCH);
static {
mUriMatcher.addURI(AUTHORITY, "person", TYPE_ALL);
mUriMatcher.addURI(AUTHORITY, "person/#", TYPE_SINGLE);//#号表示一个数字
}
以上为其声明与配置,下面是使用方法:
switch (mUriMatcher.match(uri)) {
case TYPE_ALL:
//uri匹配到第一种类型
case TYPE_SINGLE:
//uri匹配到第二种类型
default:
//uri没有匹配到这两种类型
}
这样我们就可以知道外部传入的Uri的类型了。
2.2 ContentUris用法
ContentUris用于处理Uri后面的id部分(纯数字),常用函数有:
parseId(uri): 解析Uri里的最后的id
withAppendedId(uri, id):在路径后面加上id部分
三、封装ContentProvider的步骤
提供Provider的工程简称应用A。下面是封装ContentProvider的步骤:
3.1 在Manifest中声明ContentProvider:
<provider android:name="org.test.auth.MyDataProvider"
android:authorities="org.test.auth"
android:exported="true"/>
声明后,应用安装到设备上第三方应用就能通过ContentResolver访问此Provider。
3.2 ContentProvider的代码
package org.test.auth;
import java.io.File;
import java.io.FileNotFoundException;
import android.content.ContentProvider;
import android.content.ContentUris;
import android.content.ContentValues;
import android.content.UriMatcher;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;
import android.os.ParcelFileDescriptor;
import android.text.TextUtils;
import android.util.Log;
public class MyDataProvider extends ContentProvider {
private static final String AUTHORITY = "org.test.auth";
private static final int TYPE_ALL = 1;
private static final int TYPE_SINGLE = 2;
private static final String TAG = "TEST111_DataProvider";
private MyDBHelper mDbHelper;
pri