Android之使用ContentResolver对通信录中的数据进行简单操作

本文主要是介绍Android之使用ContentResolver对通信录中的数据进行简单操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.加入读写权限

Xhtml代码 复制代码
  1. <uses-permission android:name="android.permission.READ_CONTACTS" />
  2. <uses-permission android:name="android.permission.WRITE_CONTACTS" />

<uses-permission android:name="android.permission.READ_CONTACTS" /><uses-permission android:name="android.permission.WRITE_CONTACTS" />

联系人信息Uri:

content://com.android.contacts/contacts

联系人电话Uri:

content://com.android.contacts/data/phones

联系人Email Uri:

content://com.android.contacts/data/emails


(推荐)也可以这样获取联系人信息Uri:Uri uri = ContactsContract.Contacts.CONTENT_URI;



2.查询与添加联系人的操作(单元测试用例)


Java代码 复制代码
  1. public class ContactTest extends AndroidTestCase
  2. {
  3. private static final String TAG = "ContactTest";

  4. /**
  5. * 获取通讯录中所有联系人的简单信息
  6. * @throws Throwable
  7. */
  8. public void testGetAllContact() throws Throwable
  9. {
  10. //获取联系人信息的Uri
  11. Uri uri = ContactsContract.Contacts.CONTENT_URI;
  12. //获取ContentResolver
  13. ContentResolver contentResolver = this.getContext().getContentResolver();
  14. //查询数据,返回Cursor
  15. Cursor cursor = contentResolver.query(uri, null, null, null, null);
  16. while(cursor.moveToNext())
  17. {
  18. StringBuilder sb = new StringBuilder();
  19. //获取联系人的ID
  20. String contactId = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts._ID));
  21. //获取联系人的姓名
  22. String name = cursor.getString(cursor.getColumnIndex(ContactsContract.Contacts.DISPLAY_NAME));
  23. //构造联系人信息
  24. sb.append("contactId=").append(contactId).append(",Name=").append(name);
  25. //查询电话类型的数据操作
  26. Cursor phones = contentResolver.query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI,
  27. null,
  28. ContactsContract.CommonDataKinds.Phone.CONTACT_ID +" = "+ contactId,
  29. null, null);
  30. while(phones.moveToNext())
  31. {
  32. String phoneNumber = phones.getString(phones.getColumnIndex(
  33. ContactsContract.CommonDataKinds.Phone.NUMBER));
  34. //添加Phone的信息
  35. sb.append(",Phone=").append(phoneNumber);
  36. }
  37. phones.close();

  38. //查询Email类型的数据操作
  39. Cursor emails = contentResolver.query(ContactsContract.CommonDataKinds.Email.CONTENT_URI,
  40. null,
  41. ContactsContract.CommonDataKinds.Email.CONTACT_ID + " = " + contactId,
  42. null, null);
  43. while (emails.moveToNext())
  44. {
  45. String emailAddress = emails.getString(emails.getColumnIndex(
  46. ContactsContract.CommonDataKinds.Email.DATA));
  47. //添加Email的信息
  48. sb.append(",Email=").append(emailAddress);
  49. }
  50. emails.close();
  51. Log.i(TAG, sb.toString());
  52. }
  53. cursor.close();
  54. }

  55. /**添加联系人的第一种方法:
  56. * 首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
  57. * 这时后面插入data表的依据,只有执行空值插入,才能使插入的联系人在通讯录里面可见
  58. */
  59. public void testInsert()
  60. {
  61. ContentValues values = new ContentValues();
  62. //首先向RawContacts.CONTENT_URI执行一个空值插入,目的是获取系统返回的rawContactId
  63. Uri rawContactUri = this.getContext().getContentResolver().insert(RawContacts.CONTENT_URI, values);
  64. //获取id
  65. long rawContactId = ContentUris.parseId(rawContactUri);
  66. //往data表入姓名数据
  67. values.clear();
  68. values.put(Data.RAW_CONTACT_ID, rawContactId); //添加id
  69. values.put(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE);//添加内容类型(MIMETYPE)
  70. values.put(StructuredName.GIVEN_NAME, "凯风自南");//添加名字,添加到first name位置
  71. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  72. //往data表入电话数据
  73. values.clear();
  74. values.put(Data.RAW_CONTACT_ID, rawContactId);
  75. values.put(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE);
  76. values.put(Phone.NUMBER, "13921009789");
  77. values.put(Phone.TYPE, Phone.TYPE_MOBILE);
  78. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  79. //往data表入Email数据
  80. values.clear();
  81. values.put(Data.RAW_CONTACT_ID, rawContactId);
  82. values.put(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE);
  83. values.put(Email.DATA, "kesenhoo@gmail.com");
  84. values.put(Email.TYPE, Email.TYPE_WORK);
  85. this.getContext().getContentResolver().insert(android.provider.ContactsContract.Data.CONTENT_URI, values);
  86. }

  87. /**添加联系人的第二种方法:
  88. * 批量添加联系人
  89. * @throws Throwable
  90. */
  91. public void testSave() throws Throwable
  92. {
  93. //官方文档位置:reference\android\provider\ContactsContract.RawContacts.html
  94. //建立一个ArrayList存放批量的参数
  95. ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>();
  96. int rawContactInsertIndex = ops.size();
  97. ops.add(ContentProviderOperation.newInsert(RawContacts.CONTENT_URI)
  98. .withValue(RawContacts.ACCOUNT_TYPE, null)
  99. .withValue(RawContacts.ACCOUNT_NAME, null)
  100. .build());
  101. //官方文档位置:reference\android\provider\ContactsContract.Data.html
  102. //withValueBackReference后退引用前面联系人的id
  103. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  104. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  105. .withValue(Data.MIMETYPE, StructuredName.CONTENT_ITEM_TYPE)
  106. .withValue(StructuredName.GIVEN_NAME, "小明")
  107. .build());
  108. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  109. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  110. .withValue(Data.MIMETYPE, Phone.CONTENT_ITEM_TYPE)
  111. .withValue(Phone.NUMBER, "13671323809")
  112. .withValue(Phone.TYPE, Phone.TYPE_MOBILE)
  113. .withValue(Phone.LABEL, "手机号")
  114. .build());
  115. ops.add(ContentProviderOperation.newInsert(android.provider.ContactsContract.Data.CONTENT_URI)
  116. .withValueBackReference(Data.RAW_CONTACT_ID, rawContactInsertIndex)
  117. .withValue(Data.MIMETYPE, Email.CONTENT_ITEM_TYPE)
  118. .withValue(Email.DATA, "kesen@gmail.com")
  119. .withValue(Email.TYPE, Email.TYPE_WORK)
  120. .build());
  121. ContentProviderResult[] results = this.getContext().getContentResolver()
  122. .applyBatch(ContactsContract.AUTHORITY, ops);
  123. for(ContentProviderResult result : results)
  124. {
  125. Log.i(TAG, result.uri.toString());
  126. }
  127. }
  128. }

这篇关于Android之使用ContentResolver对通信录中的数据进行简单操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/416047

相关文章

一文详解如何使用Java获取PDF页面信息

《一文详解如何使用Java获取PDF页面信息》了解PDF页面属性是我们在处理文档、内容提取、打印设置或页面重组等任务时不可或缺的一环,下面我们就来看看如何使用Java语言获取这些信息吧... 目录引言一、安装和引入PDF处理库引入依赖二、获取 PDF 页数三、获取页面尺寸(宽高)四、获取页面旋转角度五、判断

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态