bindgetphonenumber详解

发布时间:2023-05-18

bindgetphonenumber是一个基于微信小程序的API,用于获取用户手机号。在小程序登录、支付等场景中,开发者需要获取用户手机号用于验证、确认。bindgetphonenumber可以帮助开发者快速、安全获取用户手机号。

一、API介绍

bindgetphonenumber是微信小程序提供的一个API接口,用于获取用户手机号。使用该接口,需要在小程序管理后台设置业务域名,并且用户需要在授权页允许小程序获取手机号。 在小程序中,通过使用wx.getSystemInfoSync()可以获取到用户手机类型、操作系统类型、屏幕尺寸等系统信息。而bindgetphonenumber可以让开发者获取到用户的手机号码。在实际开发中,开发者可以把用户的手机号和微信openId一起传递给后台服务器进行后续处理。

//示例代码
wx.checkSession({
  success() {
    wx.login({
      success(res) {
        if (res.code) {
          //发起网络请求
          wx.request({
            url: 'https://example.com/onlogin',
            data: {
              code: res.code
            }
          })
        } else {
          console.log('登录失败!' + res.errMsg)
        }
      }
    })
  },
  fail() {
    // session_key 已经失效,需要重新执行登录流程
    wx.login({
      success(res) {
        if (res.code) {
          wx.request({
            url: 'https://example.com/onlogin',
            data: {
              code: res.code
            }
          })
        } else {
          console.log('登录失败!' + res.errMsg)
        }
      }
    })
  }
})
//对用户授权手机号进行获取
wx.getSetting({
  success(res) {
    if (!res.authSetting['scope.phoneNumber']) {
      wx.authorize({
        scope: 'scope.phoneNumber',
        success() {
          wx.getUserPhoneNumber({
            success(res) {
              console.log(res)
            }
          })
        }
      })
    }
  }
})

二、使用步骤

使用bindgetphonenumber需要按照以下步骤进行:

  1. 在后台设置业务域名
  2. 在小程序中检测用户是否授权使用手机号
  3. 如果未授权,调用wx.authorize()进行授权
  4. 调用wx.getUserPhoneNumber()接口获取用户手机号
    在实际开发中,如果用户拒绝授权使用手机号,可以弹出提示框进行提醒。
//示例代码
wx.getSetting({
  success(res) {
    if (!res.authSetting['scope.phoneNumber']) {
      wx.showModal({
        title: '授权手机号',
        content: '获取手机号需要您授权,是否授权?',
        success(res) {
          if (res.confirm) {
            wx.authorize({
              scope: 'scope.phoneNumber',
              success() {
                wx.getUserPhoneNumber({
                  success(res) {
                    console.log(res)
                  }
                })
              }
            })
          } else if (res.cancel) {
            console.log('用户点击取消')
          }
        }
      })
    }
  }
})

三、注意事项

使用bindgetphonenumber要注意以下几点:

  1. 需要在小程序管理后台设置业务域名,否则无法使用API接口。设置的业务域名需要支持https协议。
  2. 用户必须在授权页允许小程序获取手机号,否则无法获取手机号。
  3. 在获取用户手机号之前,需要检测用户是否授权,如果未授权需要调用wx.authorize()接口进行授权。
  4. 在用户授权过程中,需要给予用户充分的提示和解释,让用户充分了解小程序所获取的权限。

四、总结

bindgetphonenumber是一个非常实用的小程序API接口,可以帮助开发者快速获取用户的手机号。在实际开发中,需要注意业务域名的设置、用户授权的获取等方面,保证代码的健壮性和可靠性。