微信小程序云开发获取手机号

微信小程序云开发获取手机号


一、页面中button组件open-type配置项

open-type="getPhoneNumber" 获取用户手机号,可以从 bindgetphonenumber 回调中获取到用户信息

<button 
  class="login authorize"
  open-type="getPhoneNumber"
  bindgetphonenumber="getPhoneNumber"
>
  获取手机号
</button>

二、调用云函数获取手机号

async getPhoneNumber(event) {
  const errMsg = event.detail.errMsg
  // 判断用户是否点击允许
  if (errMsg === "getPhoneNumber:ok") {
    const cloudId = event.detail.cloudID
    const cloudIdList = [cloudId]
		// 请求云函数
    const cloudFunRes = await wx.cloud.callFunction({
      name: "getMobile", // 云函数名
      data: { cloudIdList }
    })

    const jsonStr = cloudFunRes.result.dataList[0].json
    const jsonData = JSON.parse(jsonStr)
    const phoneNumber = jsonData.data.phoneNumber
		// 手机号
    console.log('phoneNumber', phoneNumber)
  }
}

三、云函数 getMobile

3.1index.js
// 云函数入口文件
const cloud = require('wx-server-sdk')
cloud.init({
  env: cloud.DYNAMIC_CURRENT_ENV
})

// 云函数入口函数
exports.main = async (event, context) => {
  const wxContext = cloud.getWXContext()
  const openid = wxContext.OPENID
  const cloudIdList = event.cloudIdList

  try {
    const result = await cloud.openapi.cloudbase.getOpenData({
      openid: openid,
      cloudidList: cloudIdList
    })
    return result
  }
  catch (err) {
    console.error('transaction error')
    return err
  }
}

3.2 config.json
{
  "permissions": {
    "openapi": [
      "phonenumber.getPhoneNumber"
    ]
  }
}

参考文档

button 组件 open-type

获取手机号

手机号 getPhoneNumber 云调用


如果该文章能帮到你的话 麻烦点个赞 谢谢啦~

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值