contentprovider简单使用_latercat的博客-爱代码爱编程
一、设计目标
使用 Android 四大组件之一的 ContentProvider 进行数据获取
二、功能说明
ContentProvider作为Android四大组件之一,其主要作用是为不同APP之间数据共享提供统一的接口;ContentProvider通过URI来标识其他APP要访问的数据,通过ContentResolver的CURD方法实现对共享数据的操作。
(1)在 Android Studio 中新建一个空项目,命名为 MyProvider ,在其中新建一个 MyContentProvider 类用于共享该APP的数据。
(2)创建另一个空项目,命名为 MyResolver ,借助 ContentResolver 类访问MyProvider中共享的数据。
三、代码解析
1、ContentProvider
(1)在 Android Studio 中新建一个空项目,命名为 MyProvider ,在其中新建一个 MyContentProvider 类用于共享该APP的数据。
如下图所示为创建Content Provider类的详细过程,其中URI Authorities的命名为了让其他应用更方便地访问共享的数据。
创建完成后,在AndroidManifest.xml中会自动注册ContentProvider,若没有自动注册则可以手动添加。
<provider
android:name=".MyContentProvider"
android:authorities="lc.provider1"
android:enabled="true"
android:exported="true">
</provider>
(2)新建一个Java类,命名为MyDBHelper,继承SQLiteOpenHelper类,并实现onCreate和onUpgrade方法;SQLiteOpenHelper是SQLiteDatabase的一个帮助类,用来管理数据库的创建和版本的更新;对于MyDBHelper类,在onCreate()方法中利用execSQL()方法配置建表语句。
public class MyDBHelper extends SQLiteOpenHelper {
public MyDBHelper(@Nullable Context context, @Nullable String name, @Nullable SQLiteDatabase.CursorFactory factory, int version) {
super(context, name, factory, version);
}
@Override
public void onCreate(SQLiteDatabase sqLiteDatabase) {
sqLiteDatabase.execSQL("create table student (id integer primary key autoincrement,name varchar(20),age integer)");
}
@Override
public void onUpgrade(SQLiteDatabase sqLiteDatabase, int i, int i1) {
}
}
(3)新建一个MyDAO类,用于封装对数据库表的增、删、改、查基本操作。
对MyDAO构造函数进行初始化,利用getWritableDatabase()方法创建或打开一个读写数据库。
public MyDAO(Context context){
this.context = context;
MyDBHelper dbHelper = new MyDBHelper(context,"lcDB",null,1);
database = dbHelper.getWritableDatabase();
}
封装insert方法,其中Uri.parse()将String解析为Uri对象,ContentUris.withAppendedId()为Uri加上id后缀。
调用notifyChange方法,通知ContentObserver哪个uri数据发生了变化,以便及时更新页面。
public Uri lcInsert(ContentValues values){
long rowId = database.insert("student",null,values);
Uri uri = Uri.parse("content://lc.provider1/student");
Uri insertUri = ContentUris.withAppendedId(uri,rowId);
context.getContentResolver().notifyChange(insertUri,null);
return insertUri;
}
(4)由于ContentProvider是抽象类,因此在MyContentProvider类中可继承以下方法;
onCreate()、query()、insert()、delete()、update()、getType()
其中在onCreate()方法中创建MyDAO实例并调用其构造方法,完成对数据库及student表的初始化创建。对于增删改查四个操作,此处仅展示insert添加数据操作。
@Override
public boolean onCreate() {
// TODO: Implement this to initialize your content provider on startup.
context = getContext();
myDAO = new MyDAO(context);
return false;
}
重写insert()方法,调用已封装好的lcInsert()方法
@Override
public Uri insert(Uri uri, ContentValues values) {
// TODO: Implement this to handle requests to insert a new row.
return myDAO.lcInsert(values);
}
2、MyResolver
创建另一个空项目,命名为 MyResolver ,借助 ContentResolver 类访问MyProvider中共享的数据。
需要注意的是在该项目的AndroidManifest.xml文件中,一定要添加queries以授权应用之间的交互。
<queries>
<package android:name="com.example.myprovider"></package>
</queries>
通过Context中的getContentResolver方法获取MyResolver类的实例,URI字符串可以表达出是哪个应用的哪张表,并利用ContentResolver中的增删改查方法接收URI,URI字符串用Uri.parse()方法解析成Uri对象。
设置点击事件,实现点击按钮时向MyProvider应用中数据库student表插入数据。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btn_resolver = findViewById(R.id.btn_resolver);
ContentResolver resolver = getContentResolver();
Uri uri = Uri.parse("content://lc.provider1/student");
ContentValues values = new ContentValues();
values.put("name","lc");
values.put("age",20);
btn_resolver.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
resolver.insert(uri,values);
}
});
}
四、运行展示代码