微信小程序云函数快捷获取用户手机号

本文详细介绍了如何在小程序中通过云函数免鉴权调用接口获取用户手机号。首先,该功能仅针对已完成认证的小程序开放。接着,通过在WXML中设置按钮触发getPhoneNumber事件,然后在JS中处理事件,将code传给云函数。在云函数中,利用微信提供的API解码获取手机号。最后,确保代码无误后,即可在回调中获取到真实的手机号。注意区分此code与登录返回的code的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用云函数可以免鉴权调用接口,不需要access_token,更加方便

值得一提的是,小程序目前该接口针对非个人开发者,且完成了认证的小程序开放

则:若非具有以下相关资质并认真的组织,无法使用该接口直接获取用户手机号

小程序申请认证指引

认证完毕后,开始代码:

<button open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber"></button>

①.wxml中获取用户手机号的按钮,可以放在任意page中,点击触发获取手机号事件

    getPhoneNumber(e) {
        // console.log(e.detail)
        wx.cloud.callFunction({
            name: 'decodePhone',
            data: {
                code: e.detail.code
            },
            success: (res) => {
                console.log('调用云函数', res)
            }
        })
    }

②.js中绑定的对应事件,通过 bindgetphonenumber 事件获取到动态令牌code,然后把code传到后端,即云函数中(所有api.weixin.qq.com开头的接口,都要后端调用,前端不能调用),decodePhone为自定义的云函数

③创建云函数:在cloudFunction目录下右键新建node.js云函数decodePhone,需要在config.json中开启接口权限

{
    "permissions": {
        "openapi": [
            "phonenumber.getPhoneNumber"
        ]
    }
}

④编写云函数:注意!需要初始化 云环境。 然后将后端拿到的code,使用微信提供的云调用 发送给openapi.phonenumber.getPhoneNumber ,返回一个obj,其中的phoneInfo则为所需的手机号

状态:errCode:-1  系统繁忙

           errCode:0   成功

           errCode:40029  code异常(code不存在、已过期或者使用过)

const cloud = require('wx-server-sdk')
cloud.init({
    env: cloud.DYNAMIC_CURRENT_ENV
})

// 云函数入口函数
exports.main = async (event, context) => {
    let code = event.code
    try {
        const result = await cloud.openapi.phonenumber.getPhoneNumber({
            code
        })
        return result
    } catch (err) {
        throw err
    }
}

注意,此处的code(手机号获取凭证)和登录login返回的code不同,请勿混淆

⑤前面步骤无误,则可以拿到返回值,res.result.phoneInfo.purePhoneNumber即为返回的已解密的真实手机号,后续再进行需要的setData、入库等操作

success: (res) => {
    const phone = res.result.phoneInfo.purePhoneNumber   
}

### 微信小程序云开发获取用户手机号方法 #### 函数调用逻辑 当用户同意授权其手机号码时,前端会触发`getPhoneNumber`事件处理程序。此函数接收由微信返回的数据包作为参数,并从中提取`cloudID`字段用于后续操作。 ```javascript // 获取手机号 getPhoneNumber(e){ let cloudID = e.detail.cloudID; // 开放数据ID const that = this; if (!cloudID) { app.showToast('用户未授权'); return; } // 调用微信云函数来解密并获得真实的电话号码 wx.cloud.callFunction({ name: 'getPhoneNum', data: { weRunData: wx.cloud.CloudID(cloudID), } }).then(res => { console.log('成功获取到的手机号:', res.result.phoneNumber); }).catch(err => { console.error('失败原因:', err); }); } ``` 在此过程中,如果检测不到有效的`cloudID`则提示用户尚未完成必要的权限授予过程[^2]。一旦获得了合法的身份验证凭证,则通过调用名为`getPhoneNum`的自定义云函数来进行下一步骤的操作,在服务器端执行敏感信息的安全处理流程[^1]。 对于后端部分而言,Python脚本负责对接收到加密后的资料进行解析工作: ```python import json from base64 import b64decode from Crypto.Cipher import AES from binascii import a2b_hex, b2a_base64 class WXBizDataCrypt(object): def __init__(self, appId, sessionKey): self.appId = appId self.session_key = sessionKey def _unpad(self,s): return s[:-ord(s[len(s)-1:])] def decrypt(self, encrypted_data, iv): cipher = AES.new(a2b_hex(self.session_key), AES.MODE_CBC, a2b_hex(iv)) decrypted = json.loads(self._unpad(cipher.decrypt(b64decode(encrypted_data)).decode())) if decrypted['watermark']['appid'] != self.appId: raise Exception('Invalid Buffer') return decrypted['purePhoneNumber'] ``` 这段代码展示了如何利用AES算法以及Base64编码方式对来自客户端传入已加密的信息流实施逆向转换作业,最终得到明文形式下的纯数字串表示的实际移动设备联系手段——即用户手机号码[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值