title: Taro.getUserProfile(option)

sidebar_label: getUserProfile

最低 Taro 版本: 2.2.17+,3.0.29+

获取用户信息。每次请求都会弹出授权窗口,用户同意后返回 userInfo

若开发者需要获取用户的个人信息(头像、昵称、性别与地区),可以通过 Taro.getUserProfile 接口进行获取,

微信该接口从基础库 2.10.4 版本开始支持,该接口只返回用户个人信息,不包含用户身份标识符。该接口中 desc 属性(声明获取用户个人信息后的用途)后续会展示在弹窗中,请开发者谨慎填写。

开发者每次通过该接口获取用户个人信息均需用户确认,请开发者妥善保管用户快速填写的头像昵称,避免重复弹窗。

微信端调整背景和说明,请参考文档

支持情况:getUserProfile - 图1 getUserProfile - 图2 getUserProfile - 图3

参考文档

类型

  1. (option: Option) => Promise<SuccessCallbackResult>

参数

参数 类型
option Option

Option

参数 类型 必填 说明
lang keyof Language 显示用户信息的语言
desc string 声明获取用户个人信息后的用途,不超过30个字符
success (result: SuccessCallbackResult) => void 接口调用成功的回调函数
fail (res: TaroGeneral.CallbackResult) => void 接口调用失败的回调函数
complete (res: TaroGeneral.CallbackResult) => void 接口调用结束的回调函数(调用成功、失败都会执行)

SuccessCallbackResult

参数 类型 说明
userInfo UserInfo 用户信息对象
rawData string 不包括敏感信息的原始数据字符串,用于计算签名
signature string 使用 sha1( rawData + sessionkey ) 得到字符串,用于校验用户信息,详见 用户数据的签名验证和加解密
encryptedData string 包括敏感数据在内的完整用户信息的加密数据,详见 用户数据的签名验证和加解密
iv string 加密算法的初始向量,详见 用户数据的签名验证和加解密
cloudID string 敏感数据对应的云 ID,开通云开发的小程序才会返回,可通过云调用直接获取开放数据,详细 见云调用直接获取开放数据

示例代码

推荐使用 Taro.getUserProfile 获取用户信息,开发者每次通过该接口获取用户个人信息均需用户确认

  1. Taro.getUserProfile({
  2. desc: '用于完善会员资料', // 声明获取用户个人信息后的用途,后续会展示在弹窗中,请谨慎填写
  3. success: (res) => {
  4. // 开发者妥善保管用户快速填写的头像昵称,避免重复弹窗
  5. this.setState({
  6. userInfo: res.userInfo,
  7. hasUserInfo: true
  8. })
  9. }
  10. })

相关资料

相关 issue : Taro什么时候支持 getUserProfile 方法