【微信小程序】新版获取手机号码实现一键登录(uniapp语法)(完整版附源码)

news/2024/7/20 3:27:32 标签: 微信小程序, uni-app, 前端, 小程序

需求

如图,点击按钮,获取用户手机号实现一键登录,当然,用户也可以自行输入其他手机号进行登录
在这里插入图片描述在这里插入图片描述

问题

要想获取用户手机号并不复杂,但由于近几年小程序>微信小程序获取手机号的api进行了更新,当前很多帖子使用的仍是旧的方式,先调wx.login()获取code,iv,等等加密数据, 给到后端换取手机号, 现在这里说明的是更新后的获取手机号方式
ps : 现在获取手机号首先需要小程序进行认证, 然后每次调用收费0.03元
在这里插入图片描述

实现

简单说明思路 :
1.wx.login() 获取code,
2.步骤1拿到的code发送给服务端换取唯一用户标识openid
3.调getPhoneNumber() 获取phoneCode
4. 步骤3获取的phoneCode和步骤2拿到的openId一起传给服务端获取手机号
5. 完成登录

1. 手机号快速验证组件↓
https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/getPhoneNumber.html

*这里小小注意一下, uniapp回调写法@getphonenumber, 小程序>微信小程序bindgetphonenumber

<button  type="primary" open-type="getPhoneNumber" @getphonenumber="getPhoneNumber">手机号一键登录</button>

2. 在bindgetphonenumber回调中获取code动态令牌

			getPhoneNumber(e) {  // 在bindgetphonenumber回调中获取code动态令牌
				loginFn().then(res => {  // 微信登录&服务端获取openid
					console.log(res, '接口换取的openid')
					console.log('获取手机号的动态令牌:', e.detail.code) // 动态令牌
					getPhoneNumberFn(e.detail.code, res.openid).then(res2 => { // 服务端获取手机号
						if (res2.code == 0) {
							uni.setStorageSync('phoneNumber', res.content.phone_info.phoneNumber)
							uni.showToast({
								title: '登录成功'
							})
						}
					})
				})
			},

3. login.js 函数封装 : 微信登录 / 服务端获取openid / 服务断获取手机号

// 服务端接口 - 获取openid
function queryOpenIdFn(code) {
	return new Promise(resolve => {
		queryOpenId({
				code
			}).then(res => {
				if (res.code !== 0) {
					console.log('获取openid失败1:', res.msg);
					return
				}
				uni.setStorageSync('openId', res.content.openid)
				resolve(res.content)
			})
			.catch(err => {
				console.log('获取openid失败2:', err);
			})
	})
}

// 服务端接口 - 获取手机号
function getPhoneNumberFn(phoneCode, openId) {
	return new Promise(resolve => {
		getPhoneNumber({
				code:phoneCode,
				openId
			}).then(res => {
				if (res.code !== 0) {
					console.log('获取手机号失败1:', res.msg);
					return
				}
				resolve(res)
			})
			.catch(err => {
				console.log('获取手机号失败2:', err);
			})
	})
}

// 微信api : 微信登录
function loginFn() {
	return new Promise((resolve, reject) => {
		uni.login({
			success: async (res) => {	
				queryOpenIdFn(res.code).then(res => {
					resolve(res)
				})
			},
			fail: (err) => {
				console.log('login fail:', err);
			}
		})
	})
}

export {
	loginFn,
	getPhoneNumberFn
}

http://www.niftyadmin.cn/n/5161289.html

相关文章

LeetCode--584. 寻找用户推荐人

文章目录 1 题目描述2 测试用例3 解题思路 1 题目描述 表: Customer ---------------------- | Column Name | Type | ---------------------- | id | int | | name | varchar | | referee_id | int | ---------------------- 在 S…

GeoServe Web管理界面如何公网远程访问

文章目录 前言1.安装GeoServer2. windows 安装 cpolar3. 创建公网访问地址4. 公网访问Geo Servcer服务5. 固定公网HTTP地址 前言 GeoServer是OGC Web服务器规范的J2EE实现&#xff0c;利用GeoServer可以方便地发布地图数据&#xff0c;允许用户对要素数据进行更新、删除、插入…

通过对多个思维链进行元推理来回答问题11.8

通过对多个思维链进行元推理来回答问题 摘要1 引言2 背景3 方法3.1 生成推理链3.2 对推理链进行元推理 4 实验4.1 实验设置4.1.1 数据集4.1.2 方法 摘要 现代的多跳问题回答&#xff08;QA&#xff09;系统通常将问题分解为一系列推理步骤&#xff0c;称为思维链&#xff08;C…

多门店自助点餐+外卖二合一小程序源码系统 带完整搭建教程

随着餐饮业的快速发展和互联网技术的不断进步&#xff0c;越来越多的餐厅开始采用自助点餐和外卖服务。市场上许多的外卖小程序APP应运而生。下面罗峰来给大家介绍一款多门店自助点餐外卖二合一小程序源码系统。该系统结合了自助点餐和外卖服务的优势&#xff0c;为餐厅提供了一…

MQ篇---第二篇

系列文章目录 文章目录 系列文章目录一、如何保证高可用的?二、如何保证消息的可靠传输?如果消息丢了怎么办三、如何保证消息的顺序性一、如何保证高可用的? RabbitMQ 是比较有代表性的,因为是基于主从(非分布式)做高可用性的,我们就以 RabbitMQ 为例子讲解第一种 MQ 的…

C++ set map 的模拟实现

set 的模拟实现 我们在很早之前就提到过&#xff0c;set 的底层数据结构是红黑树。红黑树的实现一般都是 key-value 的结构。但是我们在使用 set 的时候明明只传入了一个模板参数哇&#xff01;我们来看库中的实现&#xff1a; 我们可以看到&#xff0c;set 的模板参数 Key 就…

安全认证框架Shiro入门学习(shiro概述和shiro入门小案例);后续整合SpringBoot,应用程序安全;

权限概述 什么是权限 什么是权限 权限管理&#xff0c;一般指根据系统设置的安全策略或者安全规则&#xff0c;用户可以访问而且只能访问自己被授权的资源&#xff0c;不多不少。权限管理几乎出现在任何系统里面&#xff0c;只要有用户和密码的系统。 权限管理再系统中一般分…

【机器学习2】模型评估

模型评估主要分为离线评估和在线评估两个阶段。 针对分类、 排序、 回归、序列预测等不同类型的机器学习问题&#xff0c; 评估指标的选择也有所不同。 1 评估指标 1.1准确率 准确率是指分类正确的样本占总样本个数的比例 但是准确率存在明显的问题&#xff0c;比如当负样本…