• uniapp开发微信小程序获取用户手机号


    功能描述:微信小程序,点击微信第三方登录,获取到当前用户绑定的手机号与openId(或unionid),请求后端接口实现登录。

    功能拆分逻辑:

    点击某个按钮,弹出请求微信授权界面。
    点击允许按钮,获取用户微信绑定的手机号与openId
    请求后端接口,实现登录。
    主要重点还是在前两步。我们来看一下实际的实现

    创建getPhoneNumber按钮
    依据微信小程序开发文档描述,小程序官方文档,先写一个button按钮,open-type 设为 getPhoneNumber,在uniapp页面中创建按钮:

    <button open-type="getPhoneNumber" @getphonenumber="onGetPhoneNumber">唤起授权</button>
    
    • 1

    ⚠️注意:
    小程序官方的写法如下,但我们在uniapp想要触发按钮点击,并进行后续操作的话,建议使用上面的写法。

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

    调用 wx.login 接口,获取code
    ⚠️ 根据官方文档描述,要想获取加密的手机号码,必须要先登录,所以我们在页面的 onload 中调用微信登录接口,并获取code。
    代码示例:

    onload(){  
        wx.login({  
            success: (res) => {  
                if (res.code) {         //微信登录成功 已拿到code  
                    // ...doSomething  
                } else {  
                    console.log('登录失败!' + res.errMsg)  
                }  
            }  
        })  
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    用 code 换取 session 和 openId
    在获取到登录成功后微信返回的 code 后,我们要用 code 换取 session 和 openid/unionid
    换取方式有两种:

    第一种不借助后端(不推荐)
    第二种借助后端
    1.不借助后端获取
    不借助后端获取,就是你必须知道你小程序的 APPID 和 secret,这个可以在 小程序控制台->开发->开发设置 中看到,然后用 APPID secret 以及上一步获取到的 code 请求微信的 auth.code2Session 接口,获取 session 和 openid auth.code2Session文档
    ⚠️这样做的话你的小程序的 APPID 和 secret会明文出现在前端代码中,有泄漏风险

    改造上面的onload事件
    代码示例:

    onload(){  
        wx.login({  
            success: (res) => {  
                if (res.code) {         //微信登录成功 已拿到code  
                    this.jsCode=res.code        //保存获取到的code  
                    uni.request({  
                        url: 'https://api.weixin.qq.com/sns/jscode2session',  
                        method:'GET',  
                        data: {  
                            appid: 'wx********',        //你的小程序的APPID  
                            secret: 'xxxxxxxxxx',       //你的小程序的secret,  
                            code: res.code              //wx.login 登录成功后的code  
                        },  
                        success: (cts) => {  
                            // 换取成功后 暂存这些数据 留作后续操作  
                            this.openid=cts.data.openid     //openid 用户唯一标识  
                            this.unionid=cts.data.unionid     //unionid 开放平台唯一标识  
                            this.session_key=cts.data.session_key     //session_key  会话密钥  
                        }  
                    });  
                } else {  
                    console.log('登录失败!' + res.errMsg)  
                }  
            }  
        })  
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    ⚠️注意:
    1.如果请求 jscode2session 接口失败,请在你的 小程序后台【request合法域名】中添加https://api.weixin.qq.com

    unionid 并不是每个账号都会返回,必须要在满足 UnionID 下发条件的情况下会返回,详见 UnionID 机制说明。
    2.借助后端获取
    借助后端获取实际上就是让后端给你一个接口,你请求后端的接口,后端再去请求微信的 jscode2session,这样你前端只需要提交code 就可以。APPID和secret都是保存在后端,不容易泄漏。
    例如,我的后端开发了个接口 https://www.xx123.com//common/unionId.do,我只需要把上面代码中的请求的地址和参数换一下就可以了。
    代码示例

    onload(){  
        wx.login({  
            success: (res) => {  
                if (res.code) {         //微信登录成功 已拿到code  
                    uni.request({  
                        url: 'https://www.xx123.com//common/unionId.do',        //演示地址,请以你的后端接口为准  
                        method:'POST',  
                        data: {  
                            code: res.code              //wx.login 登录成功后的code  
                        },  
                        success: (cts) => {  
                            // 换取成功后 暂存这些数据 留作后续操作  
                            this.openid=cts.data.openid     //openid 用户唯一标识  
                            this.unionid=cts.data.unionid     //unionid 开放平台唯一标识  
                            this.session_key=cts.data.session_key     //session_key  会话密钥  
                        }  
                    });  
                } else {  
                    console.log('登录失败!' + res.errMsg)  
                }  
            }  
        })  
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    按钮点击触发事件 onGetPhoneNumber
    做完以上几个步骤后,我们终于可以拿到加密的用户信息了,在页面的 methods 中创建点击触发事件,注意判断一下用户是否拒绝授权

    代码示例:

    methods:{  
        onGetPhoneNumber(e){  
            if(e.detail.errMsg=="getPhoneNumber:fail user deny"){       //用户决绝授权  
    
                //拒绝授权后弹出一些提示  
    
            }else{      //允许授权  
                console.log(e.detail.encryptedData)  
                e.detail.encryptedData      //加密的用户信息  
                e.detail.iv     //加密算法的初始向量  时要用到  
            }  
        }  
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    解密用户信息
    用户信息我们拿到了,加密的,接下来我们如何解密呢?
    解密方式主要有3种,第三种因为条件有限,我暂时无法尝试。主要还是讲讲前两种

    前端解密
    后端解密
    云开发解密(只适用于开通云开发的小程序)
    1.前端解密
    (1) 安装 crypto-js
    使用npm 安装 crypto-js

    安装命令:

    npm install crypto-js
    
    • 1

    (2)下载 WXBizDataCrypt.js 文件
    WXBizDataCrypt.js微信官方下载地址

    下载解压后你会发现原来是后端文件😁😁😁,没关系。
    image

    打开Node文件夹,把 WXBizDataCrypt.js 文件放入你的项目中。(比如我是放在我的common文件夹下)

    在需要解密的页面引用该文件

    import WXBizDataCrypt from "@/common/WXBizDataCrypt.js";        //请以你的实际地址为准
    
    • 1

    (3)调用解密
    改造 onGetPhoneNumber 方法,注意此处还是要用到小程序的APPID

    代码示例:

    methods:{  
        onGetPhoneNumber(e){  
            if(e.detail.errMsg=="getPhoneNumber:fail user deny"){       //用户决绝授权  
    
                //拒绝授权后弹出一些提示  
    
            }else{      //允许授权  
                let pc = new WXBizDataCrypt('wxXXXXXXX',this.session_key);           //wxXXXXXXX为你的小程序APPID  
                let data = pc.decryptData(e.detail.encryptedData , e.detail.iv);  
    
                console.log(data)       //data就是最终解密的用户信息  
    
                //后续操作。。。  
    
            }  
        }  
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17

    解密后的用户信息:
    image

    前端解密会在前端有泄漏小程序APPID的风险
    (因为我们的后端是java,官方没有dome文件,所以只能前端解密了) 😭😭

    2.后端解密
    后端解密就是同样的让后端创建一个接口,前端请求这个接口,提交 encryptedData iv 和 session_key 让后端给你返回解密后的信息。

    代码示例:

    methods:{  
        onGetPhoneNumber(e){  
            if(e.detail.errMsg=="getPhoneNumber:fail user deny"){       //用户决绝授权  
    
                //拒绝授权后弹出一些提示  
    
            }else{      //允许授权  
                uni.request({  
                    url: 'https://www.xx123.com//common/decode.do',        //演示地址,请以你的后端接口为准  
                    method:'POST',  
                    data: {  
                        iv:e.detail.iv,  
                        encryptedData: e.detail.encryptedData ,             
                        session:this.session_key,         
                    },  
                    success: (res) => {  
                        console.log(res.data)       //res.data 即为后端返回的解密数据  
                    }  
                });  
    
            }  
        }  
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
  • 相关阅读:
    【C++】STL之list深度剖析及模拟实现
    【linux kernel】linux的platform设备驱动框架分析
    <stack和queue>——《C++初阶》
    【Flutter】Flutter学习-GetX 导航操作
    2023-2028年中国高纯度糖精市场运营模式分析及发展趋势研究报告
    Spring详解(三)—— IOC 和 DI 区别
    基于Python实现的文章整合搜索引擎网站(Scrapy+Django+MySQL)
    科技前沿:IDEA插件Translation v3.6 带来革命性更新,翻译和发音更智能!
    Spark 3.0 - 5.ML Pipeline 实战之电影影评情感分析
    【每日一题】ARC071D - ### | 前缀和 | 简单
  • 原文地址:https://blog.csdn.net/m0_49515138/article/details/125478446