【HarmonyOS】获取通讯录信息

【HarmonyOS】获取通讯录信息

一、问题背景:

在Android和IOS中,获取手机通讯录信息的方式,一般是申请通讯录权限后,获得手机所有的通讯录列表信息。

在鸿蒙中,因为权限方式安全性提高的变更:将用户权限限制,不让App应用随意获取到所有的信息,只能根据用户选择后,根据用户选择的范围,传送给App。而不是App直接获取到所有的源信息。

例如,相册图片和视频的获取,都是跳到系统的组件中选择,不会将所有图片和视频访问开放给APP,进行自定义相册来展示了。这样对用户信息来说,安全层面会提升很多。

之前谣言腾x,被传偷偷上传用户的相册,也是因为权限被开放给应用了,会有这方面的技术可行性。而现在华为的这种崭新的权限提供方式,给了用户极大的安全。对应用来说,也避免了很多风险,也提升了应用开发的效率。

在鸿蒙中通讯录的信息获取,也是需要先调用华为提供的通讯录选择组件,让用户主动从通讯录中选择需要传给APP的通讯录联系人,勾选确认之后传给APP。

值得注意的是,华为提供的这种授权方式,应用APP是不需要单独申请权限的,因为我们是通过华为的安全组件,让用户主动确认勾选,将信息传给APP的,所以省略了用户再授权的过程。因为这个过程本身就代表了用户的授权。

二、解决方案:

dart 复制代码
import { contact } from '@kit.ContactsKit';
import { BusinessError } from '@kit.BasicServicesKit';

/***
 * 通讯录获取页面
 */
@Entry
@Component
struct ContactPage {

  private TAG: string = "ContactPage";

  onClickContacts = ()=>{
    // 选择联系人时的筛选条件 (是否多选)
    let contactSelectionOptions: contact.ContactSelectionOptions = { isMultiSelect:false };
    // 调用唤起通讯录选择组件,让用户去选择需要传入给APP的通讯录联系人
    let promise = contact.selectContacts(contactSelectionOptions);
    // 异步获取
    promise.then((data) => {
      // 用户选择确认之后,会在此处收到回调。
      console.log(this.TAG, `selectContacts success: data->${JSON.stringify(data)}`);
      // Array<Contact> ,返回选择的联系人对象数组。
      let contactList: Array<contact.Contact> = new Array<contact.Contact>();
      if(contactList && contactList.length > 0){
        let info: contact.Contact = contactList[0];
        let id = info.id; // 通讯录用户的唯一标识
      }
    }).catch((err: BusinessError) => {
      console.error(this.TAG, `selectContacts fail: err->${JSON.stringify(err)}`);
    });
  }

  build() {
    Row(){
      Button('点击获取通讯录信息')
        .onClick(this.onClickContacts)
    }
    .justifyContent(FlexAlign.Center)
    .size({
      width: "100%",
      height: "100%"
    })
  }
}
相关推荐
cz追天之路4 小时前
华为机考--- 字符串最后一个单词的长度
javascript·css·华为·less
4 小时前
鸿蒙——通知
华为·harmonyos·
周胡杰7 小时前
鸿蒙preferences单多例使用,本地存储类
缓存·华为·harmonyos·preferences·鸿蒙本地存储
IvanCodes7 小时前
[鸿蒙2025领航者闯关] 共享终端的隐形守护者:基于 HarmonyOS 6 的全链路隐私闭环实战
华为·harmonyos·鸿蒙
芒鸽12 小时前
鸿蒙PC上FFmpeg+Electron的Encode Smoke(P2) 排错实录:从“无法播放/时长为 0”到“保留画面且转完整时长”
ffmpeg·electron·harmonyos
2501_9444490814 小时前
帮助中心页面 Cordova&OpenHarmony 混合开发实战
harmonyos
航Hang*14 小时前
第二章:网络系统建设与运维(中级)——华为设备基本命令
运维·计算机网络·华为·ensp·交换机
北方的流星15 小时前
华为PPPoE协议的配置
运维·网络·华为
独自归家的兔15 小时前
基于 cosyvoice-v3-plus 的 个人音色复刻 (华为OBS)
人工智能·华为·语音识别
DARLING Zero two♡15 小时前
0-Day 极速响应:基于 vLLM-Ascend 在昇腾 NPU 上部署 Qwen2.5 的实战避坑指南
华为·gpu算力·vllm