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

需求

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

问题

要想获取用户手机号并不复杂,但由于近几年微信小程序获取手机号的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
}
  • 5
    点赞
  • 58
    收藏
    觉得还不错? 一键收藏
  • 37
    评论
微信小程序可以通过getPhoneNumber方法获取用户微信绑定的手机号实现一键登录功能。在前端页面中,可以使用openType="getPhoneNumber"的nut-button组件来触发获取手机号的操作。\[1\]在获取手机号的事件处理函数wxLogin中,可以通过调用wx.login获取唯一的code,然后使用该code调用后台接口获取openid。接着,根据获取到的openid调用后台接口获取token,如果存在token则进入首页,否则返回登录页面。\[2\]在代码中,需要注意@getphonenumber必须全部小写。\[3\]通过这样的流程,就可以实现微信小程序获取本机手机号一键登录的功能。 #### 引用[.reference_title] - *1* *3* [Taro:微信小程序通过获取手机号实现一键登录](https://blog.csdn.net/sg_knight/article/details/126901115)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [mpVue 微信小程序授权登录流程(即登录鉴权流程)及获取手机号一键登录教程(getPhoneNumber使用)——新增...](https://blog.csdn.net/cwin8951/article/details/131518107)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 37
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值