一、提出需求
有A,B,C三个应用,B中的数据需要被共享,所以B中定义了内容提供者ContentProvider;A应用修改了B应用的数据,插入了一条数据。有这样一个需求,此时C应用需要得到数据被修改的通知并处理相应操作。
二、示例代码
A应用
/**
* 对内容提供者进行操作
*
* @author XY
*
*/
public class MainActivity extends Activity
{
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
public void insert(View v)
{
Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
ContentResolver resolver = this.getContentResolver();
ContentValues values = new ContentValues();
values.put("name", "xy_new_new");
values.put("phone", "xy_new_111");
resolver.insert(uri, values);
}
}
B应用
package cn.xy.cotentProvider.app.providers;
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.util.Log;
import cn.xy.cotentProvider.service.DBOpeningHelper;
/**
* @author XY
*
*/
public class PersonProvider extends ContentProvider
{
private DBOpeningHelper dbHelper;
// 若不匹配采用UriMatcher.NO_MATCH(-1)返回
private static final UriMatcher MATCHER = new UriMatcher(UriMatcher.NO_MATCH);
// 匹配码
private static final int CODE_NOPARAM = 1;
private static final int CODE_PARAM = 2;
static
{
// 对等待匹配的URI进行匹配操作,必须符合cn.xyCompany.providers.personProvider/person格式
// 匹配返回CODE_NOPARAM,不匹配返回-1
MATCHER.addURI("cn.xyCompany.providers.personProvider", "person", CODE_NOPARAM);
// #表示数字 cn.xyCompany.providers.personProvider/person/10
// 匹配返回CODE_PARAM,不匹配返回-1
MATCHER.addURI("cn.xyCompany.providers.personProvider", "person/#", CODE_PARAM);
}
@Override
public boolean onCreate()
{
dbHelper = new DBOpeningHelper(this.getContext());
return true;
}
/**
* 外部应用向本应用插入数据
*/
@Override
public Uri insert(Uri uri, ContentValues values)
{
SQLiteDatabase db = dbHelper.getWritableDatabase();
switch (MATCHER.match(uri))
{
case CODE_NOPARAM:
// 若主键值是自增长的id值则返回值为主键值,否则为行号,但行号并不是RecNo列
long id = db.insert("person", "name", values);
Uri insertUri = ContentUris.withAppendedId(uri, id);
// 发出变化通知(非必须)设监听者为null。
// 若设置某个监听者则不管有多少个监听者,该监听者一定可以获得该通知
getContext().getContentResolver().notifyChange(uri, null);
return insertUri;
default:
throw new IllegalArgumentException("this is unkown uri:" + uri);
}
}
......
}
C应用
package cn.xt.contentProvider.lisenter;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.ContentObserver;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
public class MainActivity extends Activity
{
@Override
public void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
ContentResolver resolver = this.getContentResolver();
resolver.registerContentObserver(uri, true, new PersonContentObserver(new Handler()));
}
private class PersonContentObserver extends ContentObserver
{
public PersonContentObserver(Handler handler)
{
super(handler);
}
// 得到数据的变化通知,该方法只能粗略知道数据的改变,并不能判断是哪个业务操作进行的改变
@Override
public void onChange(boolean selfChange)
{
// select * from person order by id desc limit 1 // 取得最近插入的值(序号大——>小并取第一个)
Uri uri = Uri.parse("content://cn.xyCompany.providers.personProvider/person");
ContentResolver resolver = MainActivity.this.getContentResolver();
Cursor cursor = resolver.query(uri, null, null, null, "id desc limit 1");
if(cursor.moveToFirst())
{
String name = cursor.getString(cursor.getColumnIndex("name"));
Log.i("lisenter", name);
}
}
}
}
关于contentProvider的基本使用,请参看本博客博文《Android开发13——内容提供者ContentProvider的基本使用》
分享到:
相关推荐
android 内容提供者 ContentProvider
通过ContentProvider(内容提供者)将app中数据库对外开放(当然也可以对app本身开发);然后对数据库的增删改查就通过ContentProvider来实现;然后用ContentObserver(内容观察者)来监听数据是否有变化。当有变化...
android的内容提供者contentprovider的应用, 采用ContentProvider对外共享数据和监听ContentProvider中数据的变化
简单Android中的内容提供者实例,带数据库操作。
contentProvider监听的例子
ContentProvider(内容提供者)主要用于跨项目访问(操作)数据。 这个项目就是自定义内容提供者,供别的项目访问。
1、Android Room操作SQLite数据 2、ContentProvider使用,使用Room进行数据库操作
有需求做一个ContentProvider,好久没用这东西有点遗忘,晚上在家做个简化版的练手,没有测试...可能有BUG...
本篇文章小编为大家介绍,基于Android 监听ContentProvider 中数据变化的相关介绍。需要的朋友参考下
Android 系统提供了三种方式来实现数据持久化(数据存储),即文件存储、SharedPreference 存储、数据库存储,而这三种方式只是程序内部共享与存储数据,要实现跨程序共享数据,就要使用 ContentProvider(内容提供...
该文件中有两个应用,db应用通过ContentProvider对外提供数据共享,other应用提供测试代码对数据进行增删改查。 参考博客:http://blog.csdn.net/tan313/article/details/44338425
这个demo详细介绍了ContentProvider内容提供者的用法,详细介ContentProvider怎么进行数据处理,等一下用法,代码有注释,简明易懂
主要介绍了Android内容提供者ContentProvider用法,结合实例形式较为详细的分析了内容提供者ContentProvider获取及解析数据的相关技巧,需要的朋友可以参考下
ContentProvider(内容提供者)主要用于跨项目访问(操作)数据。 这是调用系统的内容题供者
博客《ContentProvider数据库共享之——读写权限与数据监听》对应源码,博客地址:http://blog.csdn.net/harvic880925/article/details/44651967
利用ContentProvider对其他应用进行共享数据,以及监听内容提供者中数据的变化。
主要是学习android的ContentProvider机制时写的测试代码,包括一个自定义内容提供者,还有一个其对应的读取示例。
此demo利用ContentProvider实现android app间的数据共享
根据本讲学习内容,学会应用通过ContentProvider提供数据,通过ContentResolver读取数据。 (1)创建2个项目,一个ProviderApp用于提供依据,一个ResoverApp用于使用数据,数据源使用SQLite数据库。 (2) 提交的...