- 浏览: 560847 次
- 性别:
- 来自: 武汉
文章分类
最新评论
-
北月与南安:
哥哥不要秀我,答案是11.38,你算出来36.43,要求N个点 ...
平均距离 -
xiao_android_jun:
[color=red][ size=xx-small ...
Android 之 进程的概念介绍 -
明子健:
小伙子,很有前途哦
《将博客搬至CSDN》 -
1140566087:
dugujiujian 写道R.layout.simple_s ...
Android 之 下拉(Spinner) 组件示例 -
dugujiujian:
R.layout.simple_spinner_dropdow ...
Android 之 下拉(Spinner) 组件示例
ContentProvider的简介:
* Android系统中存在大量的应用,当不同的应用程序直接需要共享数据时,可以使用ContentProvider来实现。
* ContentProvider是Android应用的四大组件之一,与Activity和Serivce相同,使用前需要注册。
* 当一个程序需要把自己的数据暴露给其他程序使用时,该程序就可以通过提供ContentProvider来实现,
其他应用程序就可以通过ContenResolver来操作Content Provider暴露的数据。
* 应用程序通过ContentProvider开放了自己的数据,该应用程序不需要启动,其他应用程序都可以操作开放的数据,包括增删改查操作。
自定义ContentProvider(内容提供者):
1、让自己的数据和其他的应用程序共享的两种方式:
* 创建自己的ContentProvider(继承ContentProvider的子类)
* 将自己的数据添加到已有的ContentProvider中去;(这种方式需要对应的权限);
2、创建一个ContentProvider , 主要有以下步骤:
(1) 建立数据存储系统;(可以通过Android的文件存储系统 或 SQLite数据库建立);
(2) 扩展ContentProvider 类;作用:主要工作是将要共享的数据包装并以ContentResolver 和Cursor对象能够访问
到的形式对外展示;(继承ContentProvider需要实现多个方法,这些方法在ContentResolver对象中调用);
(3) 在应用程序的AndroidMainfest.xml文件中声明ContentProvider 组件;
小贴士:
* URI 类型常量的定义:必须为该常量对象定义一个唯一的一个URI字符串,一般取类名的全称;
* SQLite数据库中 , 不管数据表中有没有其他唯一标识一个记录的字段,都应该定义一个_id字段来唯一标识一个记录;
(_id integer primary key autoincrement);
* 注册ContentProvider: <provider android:name=".类名" android:authorities="uri的唯一ID指示名称"/>
* 当修饰为static时:类.内部类.字段;
案例实现:开发一个应用,该应用对外暴露数据库,实现其它应用共用数据库的效果;
ContentProvider的子类:
常量类:
package com.example.user_defined_contentprovider;
import android.net.Uri;
import android.provider.BaseColumns;
/* 常量类 */
数据库访问类:
程序测试:
AndroidManifest.xml中的配置:
* Android系统中存在大量的应用,当不同的应用程序直接需要共享数据时,可以使用ContentProvider来实现。
* ContentProvider是Android应用的四大组件之一,与Activity和Serivce相同,使用前需要注册。
* 当一个程序需要把自己的数据暴露给其他程序使用时,该程序就可以通过提供ContentProvider来实现,
其他应用程序就可以通过ContenResolver来操作Content Provider暴露的数据。
* 应用程序通过ContentProvider开放了自己的数据,该应用程序不需要启动,其他应用程序都可以操作开放的数据,包括增删改查操作。
自定义ContentProvider(内容提供者):
1、让自己的数据和其他的应用程序共享的两种方式:
* 创建自己的ContentProvider(继承ContentProvider的子类)
* 将自己的数据添加到已有的ContentProvider中去;(这种方式需要对应的权限);
2、创建一个ContentProvider , 主要有以下步骤:
(1) 建立数据存储系统;(可以通过Android的文件存储系统 或 SQLite数据库建立);
(2) 扩展ContentProvider 类;作用:主要工作是将要共享的数据包装并以ContentResolver 和Cursor对象能够访问
到的形式对外展示;(继承ContentProvider需要实现多个方法,这些方法在ContentResolver对象中调用);
(3) 在应用程序的AndroidMainfest.xml文件中声明ContentProvider 组件;
小贴士:
* URI 类型常量的定义:必须为该常量对象定义一个唯一的一个URI字符串,一般取类名的全称;
* SQLite数据库中 , 不管数据表中有没有其他唯一标识一个记录的字段,都应该定义一个_id字段来唯一标识一个记录;
(_id integer primary key autoincrement);
* 注册ContentProvider: <provider android:name=".类名" android:authorities="uri的唯一ID指示名称"/>
* 当修饰为static时:类.内部类.字段;
案例实现:开发一个应用,该应用对外暴露数据库,实现其它应用共用数据库的效果;
ContentProvider的子类:
package com.example.user_defined_contentprovider; import android.content.ContentProvider; import android.content.ContentUris; import android.content.ContentValues; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteQueryBuilder; import android.net.Uri; import android.widget.Toast; /* 自定义ContentProvider 将数据库和其它的应用进行分享 */ public class User_defined_ContentProvider extends ContentProvider { private MySQLite helper; private final static int DB_VERSION = 2; private final static String DB_NAME = "mydb.db"; /* 当ContentProvider 启动时被调用 *//* 动作:创建数据库 */ public boolean onCreate() { helper = new MySQLite(this.getContext(),DB_NAME , null, DB_VERSION); return (helper==null) ? false:true; } /* 向 ContentProvider 中插入新的数据 */ public Uri insert(Uri uri, ContentValues values) { /* 获取数据库的连接 */ SQLiteDatabase db = helper.getWritableDatabase(); /* 操作SQLite数据库,插入数据 */ long raw_ID = db.insert(MyUser.TABLE_NAME, null, values); if(raw_ID>=0){ /* 获取新的URI地址,将获得到的ID追加到原来的URI上面 */ Uri newUri = ContentUris.withAppendedId(uri, raw_ID); return newUri; } return null; } /* 从 ContentProvider 中删除数据 */ public int delete(Uri uri, String selection, String[] selectionArgs) { return 0; } /* 返回Content Provider 中的数据(MIME) 类型 */ public String getType(Uri uri) { return null; } /* 将查询的数据以 Cursor 对象的形式返回 */ public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { SQLiteDatabase db = helper.getWritableDatabase(); SQLiteQueryBuilder sqb = new SQLiteQueryBuilder(); sqb.setTables(MyUser.TABLE_NAME); Cursor cursor = sqb.query(db, projection, selection, selectionArgs, null, null, sortOrder); return cursor; } /* 更新 ContentProvider 中已经存在的数据 */ public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) { return 0; } }
常量类:
package com.example.user_defined_contentprovider;
import android.net.Uri;
import android.provider.BaseColumns;
/* 常量类 */
public class MyUser { /* ContentProvider 的Uri */ public static final String AUTHORITY = "com.example.user_defined_contentProvider.User_defined_ContentProvider"; public static final String TABLE_NAME ="t_user"; public MyUser(){} /* 内部类:实现BaseColumns 这个接口:_id 和 _count */ public static final class User implements BaseColumns{ /* 定义Uri对象 */ public static final Uri CONTENT_URI = Uri.parse("content://"+AUTHORITY+"/"+MyUser.TABLE_NAME); /* 定义基本字段 */ public static final String NAME = "name"; public static final String AGE= "age"; } }
数据库访问类:
package com.example.user_defined_contentprovider; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; //SQLite数据库 , 用于创建数据库 public class MySQLite extends SQLiteOpenHelper { public MySQLite(Context context, String name, CursorFactory factory,int version) { super(context, name, factory, version); } /* 数据库第一次创建的时候调用,创建一张表 */ public void onCreate(SQLiteDatabase db) { /* 初始化的时候创建表 */ String sql = "create table "+MyUser.TABLE_NAME+"(_id integer primary key autoincrement,"+MyUser.User.NAME+" text , "+MyUser.User.AGE+" integer )"; db.execSQL(sql); } public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // TODO 删除表 ,删除后重新创建 db.execSQL("drop table if exists "+MyUser.TABLE_NAME+""); onCreate(db); } }
程序测试:
package com.example.user_defined_contentprovider; import android.app.Activity; import android.content.ContentValues; import android.database.Cursor; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.Toast; public class MainActivity extends Activity { private Button selectionData,insertData; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); selectionData = (Button) findViewById(R.id.selectionData); insertData = (Button) findViewById(R.id.insertData); /***************************按钮事件**********************************************/ /* 测试 :插入数据 */ insertData.setOnClickListener(new OnClickListener() { public void onClick(View v) { // TODO Auto-generated method stub insertData(); } }); /* 测试查询数据 */ selectionData.setOnClickListener(new OnClickListener() { public void onClick(View v) { selectionData(); } }); /************************************************************************************/ } /* 插 入数据 */ public void insertData(){ ContentValues values = new ContentValues(); values.put(MyUser.User.NAME, "tony"); values.put(MyUser.User.AGE, 20); this.getContentResolver().insert(MyUser.User.CONTENT_URI, values); values.clear(); } /* 查询数据 */ public void selectionData(){ /* 查询:返回一个Cursor对象 *//* 调用这个方法则间接的调用了ContentProvider子类中的query()方法,实现对数据库的操作 */ Cursor cursor = this.getContentResolver().query(MyUser.User.CONTENT_URI, null, null, null, null); /* 读取Curosor对象中的数据 */ while(cursor.moveToNext()){ String name = cursor.getString(cursor.getColumnIndex("name")); String age = cursor.getString(cursor.getColumnIndex(MyUser.User.AGE)); Toast.makeText(MainActivity.this, name+" "+age, 1000).show(); } } }
AndroidManifest.xml中的配置:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.example.user_defined_contentprovider" android:versionCode="1" android:versionName="1.0" > <uses-sdk android:minSdkVersion="10" android:targetSdkVersion="10" /> <application android:allowBackup="true" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:theme="@style/AppTheme" > <activity android:name="com.example.user_defined_contentprovider.MainActivity" android:label="@string/app_name" > <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <!-- ContentProvider为四大组件之一, 因此进行注册 --> <provider android:name=".User_defined_ContentProvider" android:authorities="com.example.user_defined_contentProvider.User_defined_ContentProvider" android:readPermission="true"/> </application> </manifest>
- user_defined_contentProvider.rar (905.4 KB)
- 下载次数: 15
发表评论
-
Android 之 网络访问服务器,解析JSON数据
2014-03-28 22:50 3424提示:在访问网络,或者服务器的数据一定要注意 网络权限的声明: ... -
Android 之 AsyncTask 异步任务
2014-03-20 08:44 3530Android ... -
Android 之 Looper Handler Message 之间的关系
2014-03-19 10:16 3678Android 的消息 ... -
Android 之 多线程与Socket联合使用案例
2014-03-19 10:15 2685多线 ... -
Android 之 多线程和Socket套接字的使用介绍
2014-03-19 10:15 4901And ... -
Android 之 实现Runnable 接口与继承Thread的区别
2014-03-19 10:15 2205实现Runnable 接口 相 ... -
Android 之 GSON解析JSON数据
2014-03-19 10:14 4504... -
Android 之 使用Pull 解析xml文件
2014-03-18 21:04 1052/** * 使用Pull进行 xml 文件的解析 ... -
Android 之 使用DOM解析xml文件
2014-03-18 21:02 2752DOM 解析 xml 格式的文件 1、 xml简介:xml ... -
Android 之 百度API 密钥安全码生成
2014-03-04 22:29 2421近期要做个关于旅游助手的应用,开始接触百度API了。大神们 ... -
Android 之 EditText属性用法介绍
2014-01-06 23:49 3997EditText的属性 EditText继承关系:View-- ... -
Android 之 自定义适配器
2014-01-08 10:40 1794自定义适配器 1、实现 * 自定义适配器要继承 BaseA ... -
Android 之 自定义控件用法介绍
2014-01-08 10:40 1722自定义效果:实现:图片和文字混合 首先创建需要组合的子布局: ... -
Android 之 资源自适应与国际化
2014-01-08 10:40 3094<!-- 国际化和资源自适应 ... -
Android 之 Parcelable 序列化
2014-01-08 10:41 2706/* 序列化 * * 作 ... -
Android 之 五大布局案例
2014-01-08 10:41 21401、LinearLayout 线性布局例子: <Lin ... -
Android 之 通知Notification
2014-03-03 22:30 3907Notification 和 NotificationMana ... -
Android 之 手机全屏显示
2014-03-03 22:30 2353/* 1、全屏状态的显示 介绍:Android 中提供了Wi ... -
Android 之 拦截手机短信并自动转发
2014-03-03 22:29 5436拦截短信和发送短信都需要相关的权限: <?xml ve ... -
Android 之 将RAW资源文件写入SD卡工具类
2014-03-01 10:09 3625package com.sun.coptfiletosd; ...
相关推荐
Android高级编程雪梨作业之自定义ContentProvider 将任务01生词本作业中生成的生词本数据库通过自定义ContentProvider的方式,共享给其他应用。 要求如下: (1) 使用自定义SQLiteOpenHelper来管理数据库; (2) 提交...
这是学习ContentProvider的第二个练习。 里面自定义ContentProvider类来与SQLite交互。 大致类容就是:通过ContentProvider,创建自己的.db,操作自己的.db. 代码里有详细的解释
总之,自定义ContentProvider和使用ContentResolver是Android平台中实现跨应用数据共享的重要手段,理解并熟练掌握这两者对于提升Android应用的可扩展性和可维护性至关重要。在实际项目中,根据需求合理设计和实现...
通过这个“android 数据库 以及自定义ContentProvider demo”,你应该能掌握如何在Android应用中使用SQLite数据库和自定义ContentProvider来实现数据的存储与共享。在实际项目中,这些技术对于构建复杂、数据驱动的...
本篇文章将深入探讨如何自定义ContentProvider以及如何使用系统提供的ContentProvider。 首先,理解ContentProvider的基本概念至关重要。ContentProvider是Android系统中的一种机制,它封装了对数据的操作,如读取...
需要指定`android:name`为自定义ContentProvider类的全名,`android:authorities`是ContentProvider的唯一标识,通常是一个应用的包名加上自定义的标识。 例如: ```xml android:name=".MyContentProvider" ...
本篇文章将深入讲解如何创建并使用自定义ContentProvider。 一、ContentProvider概述 ContentProvider作为Android四大组件之一,它为应用程序提供了一种标准接口来存储和检索数据。数据可以是任何形式,如SQLite...
总结,自定义ContentProvider是Android应用之间数据共享的重要手段。通过理解其工作原理,我们可以构建自己的数据访问接口,同时灵活地读取系统资源如联系人、彩信和通话记录。在实际开发中,结合ContentResolver,...
ContentProvider是Android四大组件之一,它的主要职责是为其他应用提供数据访问接口。自定义ContentProvider通常涉及以下步骤: 1. **创建ContentProvider类**:你需要继承`android.content.ContentProvider`类,并...
对于测试和验证,我们可以创建一个名为`TestContentProvider`的测试类,使用`Uri`、`ContentResolver`和`ContentValues`来与自定义ContentProvider交互。例如,我们可以创建一个新的用户、查询所有用户、更新特定...
8. **自定义ContentProvider的最佳实践** - 保持Uri结构清晰,避免过于复杂的Uri设计。 - 在ContentProvider中使用SQLite数据库可以方便地管理数据,同时提供高效的查询能力。 - 考虑到性能,优化`query()`等方法...
"Android 自定义ContentProvider简单实例" Android 自定义ContentProvider简单实例主要介绍了Android 自定义ContentProvider简单实例的相关资料,需要的朋友可以参考下。Android 允许我们定义自己的ContentProvider...
在android中自定义一个ContentProvider大致需要四步:1,定义数据的MetaData;2,定义一个类继承ContentProvider;3,覆写自定义类中的getType(),onCreate(),insert(),delete(),update(),query()六个方法;4,在...