微信小程序 和 Taro 两种写法,获取手机号实现一键登录

前言

自己在写微信小程序项目的时候因为用到了一键登录的功能,在网上看了很多教程大多是用login()获取code,这个方法其实是不准确的。当时我也用这个方法,但是获取的code是不生效的,得不到用户的手机号。

真正获取手机号对应code的方法是getPhoneNumber,是按钮的内置方法

微信小程序

1.首先先获取手机号对应的code

  1. button | 微信开放文档

2.具体写法

         wxml

 <button type="default" open-type="getPhoneNumber" bindgetphonenumber="getPhoneNumber">
 一键登录
 </button>

        js

 getPhoneNumber(e){
      console.log(e.detail,"请求电话回调")
    }

        效果

        到了下面这一步那么恭喜你,说明你请求电话号码的code一起获取成功了

3.根据code请求电话号码

    具体内容可以看官方文档,很简单,只需要调用官方接口传两个参数就可以正确返回电话号码

    注意:一个code只能使用一次,并且有效期为5min

  •  

Taro写微信小程序

方法和微信小程序大致相同,也是使用taro按钮自动的内置方法,还要taro的配套组件库taro-ui里面的buttton同样有内置的方法,大家感兴趣可以自行查看

1.获取手机号对应的code

2.具体写法

  • import {  Button } from "@tarojs/components";
    
    export default function Index() {
    
      // 授权获取手机号
      const getPhoneNumber = async (e: any) => {
        console.log(e.detail, "获取手机号回调");
      };
    
    return (
        <View>
             <Button
                type="primary"
                openType="getPhoneNumber"
                onGetPhoneNumber={getPhoneNumber} 
              >
                手机号码一键登录
              </Button>
        </View>
    )

3.根据code请求电话号码

具体方法和上文写的微信小程序的方法相同 

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
微信小程序可以通过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 ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

宝子向前冲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值