- Android 系统概述
- 什么是智能手机?智能手机操作系统有哪些?
- Android(安卓)是什么?
- Android 系统架构(图解)
- Android 7 新特性介绍
- Android 开发环境搭建
- Android 开发环境搭建教程(图解)
- Android SDK 是什么?
- 通过 Android Studio 创建 Android 应用程序(附带解析)
- Android Studio 的基本调试
- Android 应用程序结构:Android 组件和资源详解
- Android 四大核心组件:Activity+Service+BroadcastReceiver+ContentProvider
- Android Activity 组件及其生命周期
- Android 资源(res 和 assets 目录)
- AndroidManifest.xml 配置文件详解
- Android App Widgets 组件详解
- Android 系统的进程和线程
- Android GUI(图形用户界面)开发
- Android View 和 ViewGroup
- Android 使用 XML 文件定义用户界面
- Android 五大布局:FrameLayout、LinearLayout、AbsoluteLayout、RelativeLayout 和 TableLayout
- Android 创建 Widget 组件实例详解
- Android Button:按钮控件
- Android CheckBox:多选按钮控件
- Android RadioGroup:单选按钮控件
- Android TextView:文本框控件
- Android EditText:编辑框控件
- Android Spinner:下拉列表控件
- Android AutoCompleteTextView:自动完成文本框控件
- Android DatePicker 和 TimePicker:时间日期选择器
- Android ProgressBar:进度条控件
- Android ScrollView:滚动视图
- Android SeekBar:拖动条控件
- Android RatingBar:评价条控件
- Android ImageView 和 ImageButton:图片视图和图片按钮
- Android ImageSwitcher 和 Gallery:图片切换器和图库
- Android GridView:网格视图
- Android Tab:面板标签控件
- Android 菜单:选项菜单+上下文菜单+子菜单
- Android Bitmap(点阵图像、绘制图像)
- Android 对话框(AlertDialog+ProgressDialog)
- Android 多窗口模式(分屏模式)
- Android 事件监听器和回调方法
- Android 电话短信拍照开发教程
- Android Intent:不同应用程序之间通信的桥梁
- Android 实现拨打电话功能
- Android 实现接收短信和发送短信功能
- Android 调用相机进行拍照
- Android 多媒体开发
- Android Service 生命周期和使用方法
- Android BroadcastReceiver:接收广播
- Android 音频以及音频播放器开发实例
- Android MediaRecorder 录制音频
- Android 视频以及视频播放器实例
- Android Camera 相机以及相机程序开发实例
- Android MediaRecorder 录制视频
- Android 数据存储(SQLite 数据库、Android App 数据备份和恢复 )
- Android 数据存储之 SharedPreferences
- Android 数据存储之文件存储
- Android 使用 SQLite 数据库存数数据
- Android SQLite 数据库操作实例
- Android ContentProvider(内容提供者)
- Android 使用系统提供的 ContentProvider
- Android 自定义 ContentProvider
- Android 使用自定义 ContentProvider
- Google App Engine 是什么?
- Android APP 数据备份与恢复
- Android BackupAgent 实现数据备份与恢复
- Android BackupAgentHelper 实现数据备份与恢复
- Android 网络编程
- 借助 GPE 让 Android APP 和 Google App Engine 通信
- Android HTTP 通信
- Android HttpURLConnection 访问互联网资源
- Android 通过 GET 方式获取互联网资源
- Android 通过 POST 方式获取互联网资源
- Android Socket 编程(附带实例)
- Bluetooth(蓝牙)是什么?
- Android 蓝牙通信开发教程(详解版)
- Android 蓝牙通信开发实例演示
- WIFI(无线局域网)是什么?
- Android WiFi 开发(WiFi 编程)实例演示
- WIFI Direct(WIFI 直连)是什么?
- Android WIFI Direct 开发教程
- Android WIFI Direct 开发实例演示
- NFC(近场通信)是什么?
- Android NFC 开发教程
- Android USB 开发简介
- Android USB 附件模式开发教程
- Android USB 主机模式开发教程
- Android SIP 开发教程
- Android 智能传感器
- LBS(位置服务)和 GPS(全球定位系统)简介
- Android LBS 位置服务开发简介
- Android GPS 定位开发教程
- Google Map API 开发简介
- Android Google Map API Key 详细申请步骤
- Google Map API 开发 Android 地图应用实例
- Android 传感器开发教程
- Android 运动传感器开发教程
- Android 位置传感器开发教程
- Android 环境传感器开发教程
- Android 绘图(2D 绘图、3D 绘图)
- Android 2D 绘图开发简介
- Android 使用自定义 View 绘图
- Android 使用 Bitmap 绘图
- Android 使用 SurfaceView 绘制静态图像
- Android 使用 SurfaceView 绘制动态图像
- Android Drawable 开发简介
- Android 3D 绘图开发简介
- Android 硬件加速开发简介
- Android RenderScript 开发简介
- Android App 的国际化和本地化
- Android 国际化和本地化开发简介
- Android 手机区域设置详细步骤
- Android 未本地化应用开发教程
- Android 本地化应用开发教程
- Android 文本输入与复制粘贴
- Android 剪贴板框架开发简介
- Android 剪贴板数据转文本开发简介
- Android 复制粘贴开发教程
- Android Content Provider 复制复杂数据开发教程
- Android 一键复制粘贴开发实例
- Android 企业级应用开发
- Android 设备管理 API 概述
- Android 开发设备管理 API 应用教程
- Android 文本语音 API 开发教程
- Android TV 应用开发教程
- Android TV 应用开发实例
- Android 可穿戴设备应用开发教程
- Android 应用程序的发布
- Android 应用程序发布的步骤
- Android 为什么要为应用程序签名?
- Android 导出未签名应用程序开发步骤
- Android 生成签名文件开发教程
- Android 应用程序签名开发教程
- zipalign 工具优化应用程序开发简介
- Google Play Store( Android Market)发布简介
Android 自定义 ContentProvider
Android 系统支持任意应用程序创建自己的 ContentProvider,以便于将应用程序的数据对其他应用程序共享。
创建应用程序自己的 ContentProvider 需要以下几个步骤:
1) 当前应用程序必须具有自己的持久化数据,例如文件存储或者使用 SQLite 数据库存储。
2) 当前应用程序需要实现 ContentProvider 的子类,并通过该子类完成对持久化数据的访问。
3) 在 AndroidManifest.xml 文件中使用 <provider> 标签声明当前应用程序定义的 ContentProvider。此外,还可以在 AndroidManifest.xml 文件中指定相应的访问权限,以保证该 ContentProvider 仅被具有相应权限的应用程序访问。若不指定访问权限,则任意其他应用程序都可以访问该 ContentProvider。
在实际的应用中,为了方便应用程序所定义的 ContentProvider 被其他应用程序使用,通常会定义一个类,将 ContentProvider 相关信息以静态常量的方式放置到该类中。这样,使用该 ContentProvider 的应用程序只要将该类引用进来,就可以获取该 ContentProvider 的相关信息,进而通过其对数据进行操作。
本节以 Android SQLite 数据库操作实例教程中使用的实例 MyDbDemo 为例,为该实例中创建的 SQLite 数据库 mydb 中的 friends 数据表创建 ContentProvider,以便于其他应用程序通过该 ContentProvider 对 friends 数据表中的数据进行访问。
在实例 MyDbDemo 中的 introduction.android.mydbDemo 包下创建两个文件,分别为 MyDbProvider.java 和 MyFriendsDB.java。
MyDbProvider 继承了 ContentProvider 类,实现了针对 mydb 的 friends 数据表的相关操作。MyFriendsDB 中包含涉及 MyDbProvider 的相关信息。
MyDbProvider.java 的代码如下:
package introduction.android.mydbdemo; 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.database.sqlite.SQLiteQueryBuilder; import android.net.Uri; import android.util.Log; public class MyDbProvider extends ContentProvider { private dbHelper mydbHelper; private static final UriMatcher myUriMatcher; static { myUriMatcher = new UriMatcher(UriMatcher.NO_MATCH); myUriMatcher.addURI(MyFriendsDB.AUTHORITY, "friends", MyFriendsDB.FRIENDS); myUriMatcher.addURI(MyFriendsDB.AUTHORITY, "friends/#", MyFriendsDB.FRIENDS_ID); } @Override public int delete(Uri uri, String selection, String[] selectionArgs) { // TODO Auto-generated method stub if (myUriMatcher.match(uri) != MyFriendsDB.FRIENDS_ID) { throw new IllegalArgumentException("Wrong Insert Type: " + uri); } String id = uri.getPathSegments().get(1); if (selection == null) selection = MyFriendsDB.ID + "=" + id; else selection = MyFriendsDB.ID + "=" + id + " and " + selection; SQLiteDatabase db = mydbHelper.getWritableDatabase(); int i = db.delete(dbHelper.TB_NAME, selection, selectionArgs); if (i > 0) Log.i("myDbDemo", "数据更新成功!"); else Log.i("myDbDemo", "数据未更新!"); return i; } @Override public String getType(Uri uri) { // TODO Auto-generated method stub switch (myUriMatcher.match(uri)) { case MyFriendsDB.FRIENDS: return MyFriendsDB.CONTENT_TYPE; case MyFriendsDB.FRIENDS_ID: return MyFriendsDB.CONTENT_ITEM_TYPE; default: hrow new IllegalArgumentException("Unknown URI get type: " + uri); } } @Override public Uri insert(Uri uri, ContentValues values) { // TODO Auto-generated method stub if (myUriMatcher.match(uri) != MyFriendsDB.FRIENDS) { throw new IllegalArgumentException("Wrong Insert Type: " + uri); } if (values == null) { throw new IllegalArgumentException("Wrong Data."); } SQLiteDatabase db = mydbHelper.getWritableDatabase(); long rowId = db.insert(MyFriendsDB.TABLE_NAME, null, values); if (rowId > 0) { Uri insertUri = ContentUris.withAppendedId(MyFriendsDB.CONTENT_URI, rowId); return insertUri; } return null; } @Override public boolean onCreate() { // TODO Auto-generated method stub mydbHelper = new dbHelper(getContext(),MyFriendsDB.DATABASE_NAME, null, MyFriendsDB.DATABASE_VERSI0N); return false; } @Override public Cursor query(Uri uri, String[] projection, String selection,String[] selectionArgs, String sortOrder) { // TODO Auto-generated method stub switch (myUriMatcher.match(uri)) { case MyFriendsDB.FRIENDS: break; case MyFriendsDB.FRIENDS_ID: Log.d("MyDbProvider", "select id"); String id = uri.getPathSegments().get(1); if (selection == null) selection = MyFriendsDB.ID + "=" + id; else selection = MyFriendsDB.ID + "=" + id + " and " + selection; break; default: throw new IllegalArgumentException("Unknown URI type: " + uri); } if (sortOrder == null) sortOrder = "_id ASC"; SQLiteDatabase db = mydbHelper.getReadableDatabase(); Cursor c = db.query(MyFriendsDB.TABLE_NAME, projection, selection, selectionArgs,null,null, sortOrder); Log.d("MyDbProvider", "" + c.getCount()); return c; } @Override public int update(Uri uri, ContentValues values, String selection,String[] selectionArgs) { // TODO Auto-generated method stub if (myUriMatcher.match(uri) != MyFriendsDB.FRIENDS_ID) { throw new IllegalArgumentException("Wrong Insert Type: " + uri); } if (values == null) { throw new IllegalArgumentException("Wrong Data."); } String id = uri.getPathSegments().get(1); if (selection == null) selection = MyFriendsDB.ID + "=" + id; else selection = MyFriendsDB.ID + "=" + id + " and " + selection; SQLiteDatabase db = mydbHelper.getWritableDatabase(); int i = db.update(dbHelper.TB_NAME, values, selection, selectionArgs); if (i > 0) Log.i("myDbDemo ", "数据更新成功! "); else Log.i("myDbDemo", "数据未更新!"); return i; } }
MyFriendsDB.java 的代码如下:
package introduction.android.mydbdemo; import android.net.Uri; public class MyFriendsDB { public static final String AUTHORITY = "introduction.android.mydbdemo.myfriendsdb"; public static final String DATABASE_NAME = "mydb"; public static final int DATABASE_VERSI0N = 1; public static final String TABLE_NAME = "friends"; public static final Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/friends"); public static final int FRIENDS = 1; public static final int FRIENDS_ID = 2; public static final String CONTENT_TYPE = "vnd.android.cursor.dir/mydb.friends.all"; public static final String CONTENT_ITEM_TYPE = "vnd.android.cursor.dir/mydb.friends.item"; public static final String ID = "_id"; public static final String NAME = "name"; public static final String AGE = "age"; }
这样,就定义了针对 mydb 的 friends 数据表的 ContentProvider,最后需要在 AndroidManifest.xml 文件中添加该 ContentProvider 的相应声明和访问权限。AndroidManifest.xml 的代码如下:
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="introduction.android.mydbdemo" android:versionCode="1" android:versionName="1.0"> uses-sdk android:minSdkVersion="14" /> uses-permission android:name="introduction.android.permission.USE_MYDB" /> application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:theme="@style/AppTheme"> provider android:name="MyDbProvider" android:authorities="introduction.android.mydbdemo.MyFriendsDB" /> activity android:name=".MainActivity"> <intent-filter> action android:name="android.intent.action.MAIN" /> category android:name="android.intent.category.LAUNCHER" /> </intent-filter> /activity> /application> </manifest>
该文件通过如下代码:
<provider android:name="MyDbProvider" android:authorities="introduction.android.mydbdemo.MyFriendsDB" />
指明该 ContentProvider 名为 MyDbProvider,该 ContentProvider 的 Authority 为 introduction.android.mydbdemo.myfriendsdb。
通过如下代码:
<uses-permission android:name="introduction.android.permission.USE_MYDB"/>
指明该 ContentProvider 的权限为 introduction.android.permission.USE_MYDB,只有具有该权限的应用程序才可以访问该 ContentProvider。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论