如何实现小程序的登录支付呢?

一、背景

传统的web开发实现登陆功能,一般的做法是输入账号密码、或者输入手机号及短信验证码进行登录,服务端校验用户信息通过之后,下发一个代表登录态的 token 给客户端,以便进行后续的交互,每当token过期,用户都需要重新登录。而在微信小程序中,可以通过微信官方提供的登录能力方便地获取微信提供的用户身份标识,快速建立小程序内的用户体系,从而实现登陆功能。

实现小程序用户体系主要涉及到openid和code的概念:

调用wx.login()方法会生成code,将code作为参数传递给微信服务器指定接口,就可以获取用户的openid

对于每个小程序,微信都会将用户的微信ID映射出一个小程序 openid,作为这个用户在这个小程序的唯一标识

二、流程

  1. 用户点击登录按钮,通过绑定的事件句柄中的事件对象下的detail属性下的userInfo属性下获取到用户的昵称nickName和头像avatarUrl

  2. 通过wx.login方法返回res对象中有一个code值,code会取成一个openid

  3.通过  wx.request方法,携带res下的code,和用户的昵称nickName和头像avatarUrl去服务端请求数据,如果未注册,就会注册,在数据库生成一条新的数据给用户返回用户头像,用户昵称,用户u_id;openid 存在 ----  根据openid 查询数据,在服务器上获取了用户的资料,返回给客户端用户头像,用户昵称,用户id 。

登录流程 

下单流程

支付流程 

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值