uniapp微信小程序开发测试获取手机号码

2024-08-30 08:36

本文主要是介绍uniapp微信小程序开发测试获取手机号码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先申请测试号
注意认证但是没有完全认证不要试测试号解密如下
总结我自己的两大坑
1.官网的WXBizDataCrypt需要导入crypto要提前下载但是试了很多次没有效果重新编写这个。将crypto库换成crypto-js库
2.我一直在尝试用下有下面这个界面的测试号不行获取不到用户的code还是啥忘记了s在这里插入图片描述在这里插入图片描述
新建WXBizDataCrypt.js官网也有也可以直接负责下面的内容

import CryptoJS from 'crypto-js';class WXBizDataCrypt {constructor(appId, sessionKey) {this.appId = appId;this.sessionKey = sessionKey;}decryptData(encryptedData, iv) {// 确保 encryptedData 和 iv 都是 Base64 编码的字符串const sessionKey = CryptoJS.enc.Base64.parse(this.sessionKey);const encryptedBuffer = CryptoJS.enc.Base64.parse(encryptedData);const ivBuffer = CryptoJS.enc.Base64.parse(iv);try {// 使用 AES 解密const decrypted = CryptoJS.AES.decrypt({ ciphertext: encryptedBuffer },sessionKey,{iv: ivBuffer,mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7,});// 将解密后的数据转换为 UTF-8 字符串const decoded = decrypted.toString(CryptoJS.enc.Utf8);// 解析 JSON 数据const result = JSON.parse(decoded);// 检查解密结果中的 App IDif (result.watermark.appid !== this.appId) {throw new Error('Illegal Buffer: App ID mismatch');}return result;} catch (err) {console.error('解密失败', err);throw new Error('Illegal Buffer: ' + err.message);}}
}export default WXBizDataCrypt;

npm 下载 crypto-js:将node_modules中 crypto-js文件夹中的 crypto-js.js复制到WXBizDataCrypt同级目录
在这里插入图片描述
接下来在生成按钮

<button open-type="getPhoneNumber" @getphonenumber="getPhoneNumber"><view class="wx_text">微信授权登录</view>
</button>

接下来在第一张图片中的appid与AppSecret(小程序密钥)复制下来

getPhoneNumber(e) {uni.login({provider: 'weixin', // 使用微信登录success: (res) => {uni.request({url: 'https://api.weixin.qq.com/sns/jscode2session',method: 'GET',data: {appid: "appid自己的",secret: "AppSecret(小程序密钥)复制下来",js_code: res.code, // wx.login 登录成功后的code  grant_type: 'authorization_code',},success: (res) => {console.log('Request success:', res);if (res.data && res.data.session_key) {let pc = new WXBizDataCrypt('appid自己的', res.data.session_key);try {let data = pc.decryptData(e.detail.encryptedData, e.detail.iv);console.log('手机号码信息', data);} catch (err) {console.error('解密失败', err);}} else {console.error('未能获取 session_key:', res);}},fail: (err) => {console.error('Request failed:', err);}});},fail: (err) => {console.error('Login failed:', err);}});}

简写的方法

getPhoneNumber(e) {console.log(e)// 用户同意授权,拿到code去获取手机号uni.login({provider: 'weixin', //使用微信登录success: (res) => {uni.request({url: 'https://api.weixin.qq.com/sns/jscode2session',method: 'GET',data: {appid:"appid自己的",secret:"ppSecret(小程序密钥)复制下来",js_code: res.code, //wx.login 登录成功后的code  grant_type: 'authorization_code',},success: (res) => {let pc = new WXBizDataCrypt('appid自己的', res.data.session_key);try {let data = pc.decryptData(e.detail.encryptedData, e.detail.iv);console.log('手机号码信息', data);} catch (err) {console.error('解密失败', err);}}});}})}

这篇关于uniapp微信小程序开发测试获取手机号码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120319

相关文章

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J

java获取图片的大小、宽度、高度方式

《java获取图片的大小、宽度、高度方式》文章介绍了如何将File对象转换为MultipartFile对象的过程,并分享了个人经验,希望能为读者提供参考... 目China编程录Java获取图片的大小、宽度、高度File对象(该对象里面是图片)MultipartFile对象(该对象里面是图片)总结java获取图片

Java通过反射获取方法参数名的方式小结

《Java通过反射获取方法参数名的方式小结》这篇文章主要为大家详细介绍了Java如何通过反射获取方法参数名的方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、解决方式方式2.1: 添加编译参数配置 -parameters方式2.2: 使用Spring的内部工具类 -

Java如何获取视频文件的视频时长

《Java如何获取视频文件的视频时长》文章介绍了如何使用Java获取视频文件的视频时长,包括导入maven依赖和代码案例,同时,也讨论了在运行过程中遇到的SLF4J加载问题,并给出了解决方案... 目录Java获取视频文件的视频时长1、导入maven依赖2、代码案例3、SLF4J: Failed to lo

使用Java实现获取客户端IP地址

《使用Java实现获取客户端IP地址》这篇文章主要为大家详细介绍了如何使用Java实现获取客户端IP地址,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 首先是获取 IP,直接上代码import org.springframework.web.context.request.Requ

C++实现获取本机MAC地址与IP地址

《C++实现获取本机MAC地址与IP地址》这篇文章主要为大家详细介绍了C++实现获取本机MAC地址与IP地址的两种方式,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实际工作中,项目上常常需要获取本机的IP地址和MAC地址,在此使用两种方案获取1.MFC中获取IP和MAC地址获取

C/C++通过IP获取局域网网卡MAC地址

《C/C++通过IP获取局域网网卡MAC地址》这篇文章主要为大家详细介绍了C++如何通过Win32API函数SendARP从IP地址获取局域网内网卡的MAC地址,感兴趣的小伙伴可以跟随小编一起学习一下... C/C++通过IP获取局域网网卡MAC地址通过win32 SendARP获取MAC地址代码#i

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬