IOS开发笔记 IOS如何访问通讯录

时间:2022-01-01 09:08:42

IOS开发笔记  IOS如何访问通讯录

其实我是反对这类的需求,你说你读我的隐私,我肯定不愿意的。
幸好ios6.0 以后给了个权限控制。当打开app的时候你可以选择拒绝。


实现方法:

[plain] view
plain
copy
  1. //读取所有联系人
  2. -(void)ReadAllPeoples
  3. {
  4. //取得本地通信录名柄
  5. ABAddressBookRef tmpAddressBook = nil;
  6. if ([[UIDevice currentDevice].systemVersion floatValue]>=6.0) {
  7. tmpAddressBook=ABAddressBookCreateWithOptions(NULL, NULL);
  8. dispatch_semaphore_t sema=dispatch_semaphore_create(0);
  9. ABAddressBookRequestAccessWithCompletion(tmpAddressBook, ^(bool greanted, CFErrorRef error){
  10. dispatch_semaphore_signal(sema);
  11. });
  12. dispatch_semaphore_wait(sema, DISPATCH_TIME_FOREVER);
  13. dispatch_release(sema);
  14. }
  15. else
  16. {
  17. tmpAddressBook =ABAddressBookCreate();
  18. }
  19. //取得本地所有联系人记录
  20. if (tmpAddressBook==nil) {
  21. return ;
  22. };
  23. NSArray* tmpPeoples = (NSArray*)ABAddressBookCopyArrayOfAllPeople(tmpAddressBook);
  24. for(id tmpPerson in tmpPeoples)
  25. {
  26. //获取的联系人单一属性:First name
  27. NSString* tmpFirstName = (NSString*)ABRecordCopyValue(tmpPerson, kABPersonFirstNameProperty);
  28. NSLog(@"First name:%@", tmpFirstName);
  29. [tmpFirstName release];
  30. //获取的联系人单一属性:Last name
  31. NSString* tmpLastName = (NSString*)ABRecordCopyValue(tmpPerson, kABPersonLastNameProperty);
  32. NSLog(@"Last name:%@", tmpLastName);
  33. [tmpLastName release];
  34. //获取的联系人单一属性:Nickname
  35. NSString* tmpNickname = (NSString*)ABRecordCopyValue(tmpPerson, kABPersonNicknameProperty);
  36. NSLog(@"Nickname:%@", tmpNickname);
  37. [tmpNickname release];
  38. //获取的联系人单一属性:Company name
  39. NSString* tmpCompanyname = (NSString*)ABRecordCopyValue(tmpPerson, kABPersonOrganizationProperty);
  40. NSLog(@"Company name:%@", tmpCompanyname);
  41. [tmpCompanyname release];
  42. //获取的联系人单一属性:Job Title
  43. NSString* tmpJobTitle= (NSString*)ABRecordCopyValue(tmpPerson, kABPersonJobTitleProperty);
  44. NSLog(@"Job Title:%@", tmpJobTitle);
  45. [tmpJobTitle release];
  46. //获取的联系人单一属性:Department name
  47. NSString* tmpDepartmentName = (NSString*)ABRecordCopyValue(tmpPerson, kABPersonDepartmentProperty);
  48. NSLog(@"Department name:%@", tmpDepartmentName);
  49. [tmpDepartmentName release];
  50. //获取的联系人单一属性:Email(s)
  51. ABMultiValueRef tmpEmails = ABRecordCopyValue(tmpPerson, kABPersonEmailProperty);
  52. for(NSInteger j = 0; ABMultiValueGetCount(tmpEmails); j++)
  53. {
  54. NSString* tmpEmailIndex = (NSString*)ABMultiValueCopyValueAtIndex(tmpEmails, j);
  55. NSLog(@"Emails%d:%@", j, tmpEmailIndex);
  56. [tmpEmailIndex release];
  57. }
  58. CFRelease(tmpEmails);
  59. //获取的联系人单一属性:Birthday
  60. NSDate* tmpBirthday = (NSDate*)ABRecordCopyValue(tmpPerson, kABPersonBirthdayProperty);
  61. NSLog(@"Birthday:%@", tmpBirthday);
  62. [tmpBirthday release];
  63. //获取的联系人单一属性:Note
  64. NSString* tmpNote = (NSString*)ABRecordCopyValue(tmpPerson, kABPersonNoteProperty);
  65. NSLog(@"Note:%@", tmpNote);
  66. [tmpNote release];
  67. //获取的联系人单一属性:Generic phone number
  68. ABMultiValueRef tmpPhones = ABRecordCopyValue(tmpPerson, kABPersonPhoneProperty);
  69. for(NSInteger j = 0; j < ABMultiValueGetCount(tmpPhones); j++)
  70. {
  71. NSString* tmpPhoneIndex = (NSString*)ABMultiValueCopyValueAtIndex(tmpPhones, j);
  72. NSLog(@"tmpPhoneIndex%d:%@", j, tmpPhoneIndex);
  73. [tmpPhoneIndex release];
  74. }
  75. CFRelease(tmpPhones);
  76. }
  77. //释放内存
  78. [tmpPeoples release];
  79. CFRelease(tmpAddressBook);
  80. }

解释下代码:由于ios6.0系统的升级,对客户隐私有了一个较大的提示。

以前
[plain] view
plain
copy
  1. tmpAddressBook =ABAddressBookCreate();这样就可以读取了,但是现在要做一个判断了。可以具体看看代码。
[plain] view
plain
copy
  1. 把通讯录取出来放在一个array里面。这样你就可以对数组进行你的要求了。
[plain] view
plain
copy

备注:

苹果中文语言貌似有点问题。ios6.0  会提示你的app访问日历。。。。
然后网上查了下资料。可以参照微信访问通讯录的形式,给客户一个提示
他是在plist中  添加一项在XCode里显示的是Privacy - Contacts Usage Description。后面的string就是你要想提示的文字内容
“Privacy - Location Usage Description”。这个是定位位置提示。其他类似。
IOS开发笔记  IOS如何访问通讯录

备注二:

分享一个测试经验,也是从网上看到的。
一把苹果的app访问位置或者通讯录,第一次都会有一个提示让你选择。
但是第二次及以后,即时删掉,也不会再出现了。
如果想再次出现,可以  设置-通用-还原-还原位置与隐私
这样你再次点击你的app就会再次出现了。