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

相关文章

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Java发送SNMP至交换机获取交换机状态实现方式

《Java发送SNMP至交换机获取交换机状态实现方式》文章介绍使用SNMP4J库(2.7.0)通过RCF1213-MIB协议获取交换机单/多路状态,需开启SNMP支持,重点对比SNMPv1、v2c、v... 目录交换机协议SNMP库获取交换机单路状态获取交换机多路状态总结交换机协议这里使用的交换机协议为常

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

Spring Boot中获取IOC容器的多种方式

《SpringBoot中获取IOC容器的多种方式》本文主要介绍了SpringBoot中获取IOC容器的多种方式,包括直接注入、实现ApplicationContextAware接口、通过Spring... 目录1. 直接注入ApplicationContext2. 实现ApplicationContextA

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

Spring Security重写AuthenticationManager实现账号密码登录或者手机号码登录

《SpringSecurity重写AuthenticationManager实现账号密码登录或者手机号码登录》本文主要介绍了SpringSecurity重写AuthenticationManage... 目录一、创建自定义认证提供者CustomAuthenticationProvider二、创建认证业务Us

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

Python获取浏览器Cookies的四种方式小结

《Python获取浏览器Cookies的四种方式小结》在进行Web应用程序测试和开发时,获取浏览器Cookies是一项重要任务,本文我们介绍四种用Python获取浏览器Cookies的方式,具有一定的... 目录什么是 Cookie?1.使用Selenium库获取浏览器Cookies2.使用浏览器开发者工具