以前用ContentResolver只是读取一下手机里的数据,现在公司做的东西也用不到提供给别人数据,今天主席提醒才想起来,我还跟这个传说中的四大组件之一不是很熟,今天就来研究一下它。
1.ContentProvider简介
当应用继承ContentProvider类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据。虽然使用其他方法也可以对外共享数据,但数据访问方式会因数据存储的方式而不同,如:采用文件方式对外共享数据,需要进行文件操作读写数据;采用sharedpreferences共享数据,需要使用sharedpreferences API读写数据。而使用ContentProvider共享数据的好处是统一了数据访问方式。
2.ContentProvider应用场景
(1)存储和读取数据
(2)实现数据共享
下面通过一个demo分享一下数据,供其他app操作(这里只实现了查询)
/**
*
*/
package com.zimo.datebase;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
/**
* @author 子墨
*
* 2015-3-4下午3:10:16
*/
public class MyDatabaseHelper extends SQLiteOpenHelper {
public MyDatabaseHelper(Context context, String name,
CursorFactory factory, int version) {
super(context, name, factory, version);
}
/* (non-Javadoc)
* @see android.database.sqlite.SQLiteOpenHelper#onCreate(android.database.sqlite.SQLiteDatabase)
*/
@Override
public void onCreate(SQLiteDatabase db) {
/**
* 創建student表
*/
db.execSQL("create table student("+"id integer primary key autoincrement,"+"name text,"+"number integer,"+"sex text)");
}
/* (non-Javadoc)
* @see android.database.sqlite.SQLiteOpenHelper#onUpgrade(android.database.sqlite.SQLiteDatabase, int, int)
*/
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
/**
* 刪除表并重建
*/
db.execSQL("drop table if exists student");
onCreate(db);
}
}
以上代码使用SQLite存储数据,建了一张表(student)
package com.zimo.datebase;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
public class MainActivity extends Activity implements OnClickListener {
MyDatabaseHelper helper;
SQLiteDatabase db;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Button button=(Button) findViewById(R.id.button1);
button.setOnClickListener(this);
helper=new MyDatabaseHelper(getApplicationContext(), "student.db", null, 1);
db=helper.getWritableDatabase();
ContentValues contentValues=new ContentValues();
contentValues.put("name", "zimo");
contentValues.put("number", 111);
contentValues.put("sex", "f");
db.insert("student",null,contentValues);
contentValues.put("name", "thea");
contentValues.put("number", 112);
contentValues.put("sex", "f");
db.insert("student",null,contentValues);
}
@Override
public void onClick(View v) {
Cursor cursor = db.query("student", null, null, null, null, null, null);
if (!cursor.moveToFirst()) {
return;
}else {
while (cursor.moveToNext()) {
String name=cursor.getString(cursor.getColumnIndex("name"));
int number=cursor.getInt(cursor.getColumnIndex("number"));
String sex=cursor.getString(cursor.getColumnIndex("sex"));
Log.d("com.zimo.datebase", "姓名:"+name+"學號:"+number+"性別:"+sex);
}
}
}
}
代码贴到这应该都是你熟悉的,就是创建一个数据库(student.db),然后创建了一张表(student),然后在表中插入数据,这里问了确保我的数据已经插入,我又取出来看了看,这一段比较多余,可以忽略
下面就开始共享数据,我个人理解,就是提供个接口(uri)供别人访问,也没有多复杂,下面开始实现,要是提供ContentProvider功能,就要实现ContentProvider这个抽象方法
/**
*
*/
package com.zimo.datebase;
import android.content.ContentProvider;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.net.Uri;
/**
* @author 子墨
*
* 2015-3-4下午3:25:26
*/
public class MyProvider extends ContentProvider {
private MyDatabaseHelper helper;
/* (non-Javadoc)
* @see android.content.ContentProvider#onCreate()
*/
@Override
public boolean onCreate() {
helper=new MyDatabaseHelper(getContext(), "student.db", null, 1);
return true;
}
/* (non-Javadoc)
* @see android.content.ContentProvider#query(android.net.Uri, java.lang.String[], java.lang.String, java.lang.String[], java.lang.String)
*/
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String sortOrder) {
SQLiteDatabase db=helper.getReadableDatabase();
Cursor cursor=db.query("student", projection, selection, selectionArgs, null, null, sortOrder);
return cursor;
}
/* (non-Javadoc)
* @see android.content.ContentProvider#getType(android.net.Uri)
*/
@Override
public String getType(Uri uri) {
// TODO Auto-generated method stub
return null;
}
/* (non-Javadoc)
* @see android.content.ContentProvider#insert(android.net.Uri, android.content.ContentValues)
*/
@Override
public Uri insert(Uri uri, ContentValues values) {
return null;
}
/* (non-Javadoc)
* @see android.content.ContentProvider#delete(android.net.Uri, java.lang.String, java.lang.String[])
*/
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
return 0;
}
/* (non-Javadoc)
* @see android.content.ContentProvider#update(android.net.Uri, android.content.ContentValues, java.lang.String, java.lang.String[])
*/
@Override
public int update(Uri uri, ContentValues values, String selection,
String[] selectionArgs) {
return 0;
}
}
<provider android:name=".MyProvider"
android:authorities="com.zimo.datebase.MyProvider">
</provider>
ok了,你通过content://com.zimo.datebase.MyProvider/student这几接口,就能访问到这个app的数据了.
下面是测试的部分:
package com.zimo.getdata;
import android.net.Uri;
import android.os.Bundle;
import android.annotation.SuppressLint;
import android.app.Activity;
import android.content.ContentResolver;
import android.database.Cursor;
import android.util.Log;
import android.view.Menu;
public class MainActivity extends Activity {
@SuppressLint("NewApi")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ContentResolver resolver=this.getContentResolver();
Uri uri=Uri.parse("content://com.zimo.datebase.MyProvider/student");
Cursor cursor=resolver.query(uri, null, null, null, null, null);
if (!cursor.moveToFirst()) {
return;
}else {
while (cursor.moveToNext()) {
String name=cursor.getString(cursor.getColumnIndex("name"));
int number=cursor.getInt(cursor.getColumnIndex("number"));
String sex=cursor.getString(cursor.getColumnIndex("sex"));
Log.d("com.zimo.getdata", "姓名:"+name+"學號:"+number+"性別:"+sex);
}
}
}
}
代码下载地址:http://download.csdn.net/detail/elinavampire/8472781