文档章节

Android读取系统联系人

喜欢敲代码的感觉
 喜欢敲代码的感觉
发布于 2015/09/11 18:52
字数 1756
阅读 155
收藏 1
使用 ContentProvider共享数据:
当应用继承 ContentProvider 类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据。虽 然使用其他方法也可以对外共享数据,但数据访问方式会因数据存储的方式而不同,如:采用文件方式对外 共享数据,需要进行文件操作读写数据;采用 sharedpreferences 共享数据,需要使用 sharedpreferences API 读写数据。而使用 ContentProvider 共享数据的好处是 统一了数据访问方式
当应用需要通过 ContentProvider 对外共享数据时,第一步需要继承 ContentProvider 并重写下面方法:
public class PersonContentProvider extends ContentProvider{
public boolean onCreate()
public Uri insert(Uri uri, ContentValues values)
public int delete(Uri uri, String selection, String[] selectionArgs)
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs)
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder)
public String getType(Uri uri) }
第二步需要在 AndroidManifest.xml 使用 <provider> 对该 ContentProvider 进行配置,为了能让其他应用找到该 ContentProvider ContentProvider 采用了 authorities (主机名 / 域名)对它进行唯一标识,你可以把 ContentProvider 看作是一个网站(想想,网站也是提供数据者), authorities 就是他的域名:
<manifest .... >
<application android:icon="@drawable/icon" android:label="@string/app_name">
<provider android:name=".PersonContentProvider" android:authorities="cn.itcast.provider.personprovider"/>
</application>
</manifest>
注意:一旦应用继承了 ContentProvider 类,后面我们就会把这个应用称为 ContentProvider (内容提供者)。
l
Uri 介绍:
Uri 代表了要操作的数据, Uri 主要包含了两部分信息: 1 》需要操作的 ContentProvider 2 》对 ContentProvider 的什么数据进行操作,一个 Uri 由以下几部分组成:
l
ContentProvider (内容提供者)的 scheme 已经由 Android 所规定, scheme 为: content://
主机名(或叫 Authority )用于唯一标识这个 ContentProvider ,外部调用者可以根据这个标识来找到它。
路径( path )可以用来表示我们要操作的数据,路径的构建应根据业务而定,如下 :
要操作 person 表中 id 10 的记录,可以构建这样的路径 :/person/10
要操作 person 表中 id 10 的记录的 name 字段, person/10/name
要操作 person 表中的所有记录,可以构建这样的路径 :/person
要操作 xxx 表中的记录,可以构建这样的路径 :/xxx
当然要操作的数据不一定来自数据库,也可以是文件等他存储方式,如下 :
要操作 xml 文件中 person 节点下的 name 节点,可以构建这样的路径: /person/name
如果要把一个字符串转换成 Uri ,可以使用 Uri 类中的 parse() 方法,如下:
Uri uri = Uri.parse("content://cn.itcast.provider.personprovider/person")

l UriMatcher 类使用介绍:
因为 Uri 代表了要操作的数据,所以我们很经常需要解析 Uri ,并从 Uri 中获取数据。 Android 系统提供了两个用于操 Uri 的工具类,分别为 UriMatcher ContentUris 。掌握它们的使用,会便于我们的开发工作。
UriMatcher 类用于匹配 Uri ,它的用法如下:
首先第一步把你需要匹配 Uri 路径全部给注册上,如下:
// 常量 UriMatcher.NO_MATCH 表示不匹配任何路径的返回码
UriMatcher sMatcher = new UriMatcher(UriMatcher.NO_MATCH);
// 如果 match() 方法匹配 content://cn.itcast.provider.personprovider/person 路径,返回匹配码为 1
sMatcher.addURI( cn.itcast.provider.personprovider , person , 1);// 添加需要匹配 uri ,如果匹配就会返回匹配码
// 如果 match() 方法匹配 content://cn.itcast.provider.personprovider/person/230 路径,返回匹配码为 2
sMatcher.addURI(“cn.itcast.provider.personprovider”, “person/#”, 2); //# 号为通配符
switch (sMatcher.match( Uri.parse("content://cn.itcast.provider.personprovider/person/10" ) )) {
case 1
break;
case 2
break;
default:// 不匹配
break;
}
注册完需要匹配的 Uri 后,就可以使用 sMatcher.match(uri) 方法对输入的 Uri 进行匹配,如果匹配就返回匹配码, 匹配码是调用 addURI() 方法传入的第三个参数,假设匹配 content://cn.itcast.provider.personprovider/person 路径,返回的匹配码为 1
l ContentUris 类使用介绍:
ContentUris 类用于获取 Uri 路径后面的 ID 部分,它有两个比较实用的方法:
withAppendedId(uri, id) 用于为路径加上 ID 部分:
Uri uri = Uri.parse("content://cn.itcast.provider.personprovider/person")
Uri resultUri = ContentUris.withAppendedId(uri, 10);
// 生成后的 Uri 为: content://cn.itcast.provider.personprovider/person/10
parseId(uri) 方法用于从路径中获取 ID 部分:
Uri uri = Uri.parse("content://cn.itcast.provider.personprovider/person/10")
long personid = ContentUris.parseId(uri);// 获取的结果为 :10
l 使用 ContentProvider 共享数据:
ContentProvider 类主要方法的作用:
public boolean onCreate()
该方法在 ContentProvider 创建后就会被调用, Android 在系统启动时就会创建 ContentProvider
public Uri insert(Uri uri, ContentValues values)
该方法用于供外部应用往 ContentProvider 添加数据。
public int delete(Uri uri, String selection, String[] selectionArgs)
该方法用于供外部应用从 ContentProvider 删除数据。
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs)
该方法用于供外部应用更新 ContentProvider 中的数据。
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder)
该方法用于供外部应用从 ContentProvider 中获取数据。
public String getType(Uri uri)
该方法用于返回当前 Url 所代表数据的 MIME 类型。如果操作的数据属于集合类型,那么 MIME 类型字符串应该以 vnd.android.cursor.dir/ 开头,例如:要得到所有 person 记录的 Uri content://cn.itcast.provider.personprovider/person ,那么返回的 MIME 类型字符串应该为: vnd.android.cursor.dir/person 。如果要操作的数据属于单一数据,那么 MIME 类型字符串应该以 vnd.android.cursor.item/ 开头,例如:得到 id 10 person 记录, Uri content://cn.itcast.provider.personprovider/person/10 ,那么返回的 MIME 类型字符串应该为: vnd.android.cursor.item/person
l 使用 ContentResolver 操作 ContentProvider 中的数据:
当外部应用需要对 ContentProvider 中的数据进行添加、删除、修改和查询操作时,可以使用 ContentResolver 来完成,要获取 ContentResolver 对象,可以使用 Activity 提供的 getContentResolver() 方法。 ContentResolver 类提供了与 ContentProvider 类相同签名的四个方法:
public Uri insert(Uri uri, ContentValues values)
该方法用于往 ContentProvider 添加数据。
public int delete(Uri uri, String selection, String[] selectionArgs)
该方法用于从 ContentProvider 删除数据。
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs)
该方法用于更新 ContentProvider 中的数据。
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder)

该方法用于从ContentProvider中获取数据。



//代码

ContentResolver cr = getContentResolver();  //向联系人插入数据 ContentValues cValue = new ContentValues();  Uri uri = cr.insert(ContactsContract.RawContacts.CONTENT_URI, cValue);  Long raw_contact_id = ContentUris.parseId(uri);  cValue.clear();  //插入联系人  cValue.put(StructuredName.RAW_CONTACT_ID, raw_contact_id); cValue.put(StructuredName.DISPLAY_NAME, "Breath");  cValue.put(StructuredName.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);  uri = cr.insert(ContactsContract.Data.CONTENT_URI, cValue);  cValue.clear(); //插入联系电话 cValue.put(Phone.RAW_CONTACT_ID, raw_contact_id); cValue.put(Phone.NUMBER, "1389746423"); cValue.put(Phone.MIMETYPE, Phone.CONTENT_ITEM_TYPE); uri = cr.insert(ContactsContract.Data.CONTENT_URI, cValue);   Log.i("Info", "插入数据"); 
//代码


ContentResolver cr = getContentResolver(); Cursor c = cr.query(Contacts.CONTENT_URI,         new String[]{Contacts._ID, Contacts.DISPLAY_NAME},                  
        null,                 
        null,                  
        null); if (c != null){      
    while(c.moveToNext()){
        Log.i("info", "username : " + c.getString(c.getColumnIndex(Contacts.DISPLAY_NAME)));          
        int id = c.getInt(c.getColumnIndex(Contacts._ID));                        //根据联系人ID查询出联系人的电话号码            
        Cursor cc = cr.query(Phone.CONTENT_URI,                          
            new String[]{Phone.NUMBER, Phone.TYPE},                           
            Phone.CONTACT_ID + "=" + id,                          
            null,                          
            null);             
        if(cc != null){             
            while(cc.moveToNext()){                 
                int type = cc.getInt(cc.getColumnIndex(Phone.TYPE));                   
                String phone = cc.getString(cc.getColumnIndex(Phone.NUMBER));                  
                switch (type){                      
                    case Phone.TYPE_HOME:
                        Log.i("info", "Phone_Home :" + phone);                          
                        break;                      
                    case Phone.TYPE_MOBILE:
                        Log.i("info", "Phone_Mobile :" + phone);                          
                        break;                              }
            }
            cc.close();          }         //根据联系人ID查询出联系人的邮箱地址           Cursor ccc = cr.query(Email.CONTENT_URI,                      new String[]{Email.DATA,Email.TYPE},                      Email._ID + "=" + id,                      null,                      null);          if(ccc != null){              while (ccc.moveToNext()){                 int type = ccc.getInt(ccc.getColumnIndex(Email.TYPE));                   String email = ccc.getString(ccc.getColumnIndex(Email.DATA));                  switch (type){                     case Email.TYPE_HOME:
                        Log.i("info", "Email_Home : " + email);                          break;                      case Email.TYPE_WORK:
                        Log.i("info", "Email_Work : " + email);                          break;                   }
            }
            ccc.close();          }
    }
    c.close(); }


© 著作权归作者所有

喜欢敲代码的感觉
粉丝 1
博文 41
码字总数 8149
作品 0
西安
程序员
私信 提问
Android SMS 短信 与 Contacts 联系人关联

Android 的SMS读取短信,可以获取发信人/收信人的手机号码(address),Contacts的联系人,可以过滤手机号码(address),因此SMS可以通过手机号码(address)关联到Contacts联系人 SMS - Co...

鉴客
2012/03/09
1K
0
Android本地的Content Provider

Android本地的Content Provider Android 暴露了许多 Content Provider 来访问本地的数据库。 你可以使用之前描述的技巧来使用本地的 Content Provider 。可变通的地方, android.provider 类...

晨曦之光
2012/03/05
690
0
Android Q (Android 10.0)

通常,我们会在三月份的某个时候看到第一个开发人员的预览版。然后,在 Google I/O上,Google发布了另一个包含更多新功能和优化的开发人员预览版。最后,在八月的第一周,我们的手机上有了新...

desaco
03/18
0
0
Android Contacts(二)—— SMS 短信 与 Contacts 联系人关联

Android 的SMS读取短信,可以获取发信人/收信人的手机号码(address),Contacts的联系人,可以过滤手机号码(address),因此SMS可以通过手机号码(address)关联到Contacts联系人 SMS - Co...

长平狐
2013/01/06
88
0
Android开发_android权限

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zhangty0223/article/details/9389879 访问登记属性 android.permission.ACCESSCHECKINPROPERTIES ,读取或写...

张腾元_Ternence
2013/07/20
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Phpstorm2018 永久激活

1、安装phpstorm,安装包请自行官网下载 http://www.jetbrains.com/phpstorm/download/ 2、下载JetbrainsCrack.jar文件,存放至你的phpstorm执行文件同级目录下 下载JetbrainsCrack.jar 提取...

happyfish319
30分钟前
6
0
谈一谈Android进程间通信的几种方式

###来看一下Android中除了AIDL还有哪些进程间通信的方式: 1、Bundle Bundle实现了Parcelable,所以在Android中我们可以通过Intent在不同进程间传递Bundle数据。 但是在Intent 传输数据的过程...

二营长的意大利炮手
31分钟前
7
0
互联网薪资“高开低走”,你的能力是否真的可以匹配高薪?

对于国内外主流互联网大厂,技术出身似乎已经成为各大掌门人的必备标签。谷歌 CEO 桑达尔·皮查伊、马克·扎克伯格、李彦宏、马化腾、雷军等等皆为技术人出身,都曾参与了公司内部重要产品的...

Java技术剑
32分钟前
9
0
java 多线程

线程声明周期 线程的五个状态:新建,就绪,运行,阻塞,死亡。 其中就绪和运行两个状态客户互相转换,但运行到阻塞,阻塞到就绪,只能单向转换。 刚new出的线程就是【新建】状态,调用start...

雷开你的门
34分钟前
11
0
构造器Constructor是否可被overrid

构造器不能被重写,不能用static修饰构造器,只能用public private protected这三个权限修饰符,且不能有返回语句。

无名氏的程序员
38分钟前
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部