一、背景

传统的web开发实现登陆功能,一般的做法是输入账号密码、或者输入手机号及短信验证码进行登录。

服务端校验用户信息通过之后,下发一个代表登录态的 token 给客户端,以便进行后续的交互,每当token过期,用户都需要重新登录。

而在微信小程序中,可以通过微信官方提供的登录能力方便地获取微信提供的用户身份标识,快速建立小程序内的用户体系,从而实现登陆功能。

实现小程序用户体系主要涉及到openid和code的概念:
1.调用wx.login()方法会生成code,将code作为参数传递给微信服务器指定接口,就可以获取用户的openid。
2.对于每个小程序,微信都会将用户的微信ID映射出一个小程序 openid,作为这个用户在这个小程序的唯一标识。

二、流程

微信小程序登陆具体实现的逻辑如下图所示:

1.通过  wx.login()  获取到用户的code判断用户是否授权读取用户信息,调用wx.getUserInfo 读取用户数据。
2.由于小程序后台授权域名无法授权微信的域名,所以需要自身后端调用微信服务器获取用户信息。
3.通过 wx.request() 方法请求业务方服务器,后端把 appid , appsecret  和 code 一起发送到微信服务器。
appid 和 appsecret 都是微信提供的,可以在管理员后台找到。
4.微信服务器返回了 openid 及本次登录的会话密钥 session_key。
5.后端从数据库中查找 openid ,如果没有查到记录,说明该用户没有注册,如果有记录,则继续往下走。
6.session_key 是对用户数据进行加密签名的密钥。为了自身应用安全,session_key 不应该在网络上传输。
7.然后生成 session并返回给小程序。
8.小程序把 session 存到  storage 里面。
9.下次请求时,先从 storage 里面读取,然后带给服务端。
10.服务端对比 session 对应的记录,然后校验有效期。

更加详细的功能图如下所示:

三、扩展

实际业务中,我们还需要登录态是否过期,通常的做法是在登录态(临时令牌)中保存有效期数据,该有效期数据应该在服务端校验登录态时和约定的时间(如服务端本地的系统时间或时间服务器上的标准时间)做对比。
这种方法需要将本地存储的登录态发送到小程序的服务端,服务端判断为无效登录态时再返回需重新执行登录过程的消息给小程。

另一种方式可以通过调用wx.checkSession检查微信登陆态是否过期:
1.如果过期,则发起完整的登录流程
2.如果不过期,则继续使用本地保存的自定义登录态

这种方式的好处是不需要小程序服务端来参与校验,而是在小程序端调用AP,流程如下所示:

这篇文章是转载:JS每日一题
微信公众号:JS每日一题

微信小程序的登录流程相关推荐

  1. 微信小程序用户登录流程思路及主要代码

    微信小程序用户登录流程思路 由于微信官方不允许在刚进入小程序的时候,弹出用户登陆页面,需要在进入小程序后,用户主动点击才能进入登陆页面.此时,将会给小程序开发者在设计用户登陆页面时,带来一定的麻烦.现 ...

  2. 新版微信小程序授权登录流程及问题汇总(getUserProfile)

    问题来源:前不久去面试的时候有面试官问我你有自己的博客啥的吗?只能很尴尬的说没有.其实一直想有一个属于自己的博客啥的去记录自己在开发过程中遇到的问题,正好现在微信小程序比较流行,就花了两天自己搞了一个 ...

  3. 面试官:说说微信小程序的登录流程?

    一.背景 传统的web开发实现登陆功能,一般的做法是输入账号密码.或者输入手机号及短信验证码进行登录 服务端校验用户信息通过之后,下发一个代表登录态的 token 给客户端,以便进行后续的交互,每当t ...

  4. 解密微信小程序Java登录流程(ssm实现具体功能)

    点击上方"好好学java",选择"置顶公众号" 优秀学习资源.干货第一时间送达! 精彩内容 java实战练习项目教程 2018微服务资源springboot.s ...

  5. 微信小程序Java登录流程(ssm实现具体功能和加解密隐私信息问题解决方案)

    文章有不当之处,欢迎指正,如果喜欢微信阅读,你也可以关注我的微信公众号:好好学java,获取优质学习资源. 一.登录流程图 20180510145856113.png 二.小程序客户端 doLogin ...

  6. 微信小程序Java登录流程(ssm实现具体功能和问题解决方案)

    一.登录流程图 二.小程序客户端 doLogin:function(callback = () =>{}){ let that = this; wx.login({success:functio ...

  7. 微信小程序Java登录流程(ssm实现具体功能和加解密隐私信息问题解决方案)...

    文章有不当之处,欢迎指正,如果喜欢微信阅读,你也可以关注我的微信公众号:好好学java,获取优质学习资源. 一.登录流程图 二.小程序客户端 doLogin:function(callback = ( ...

  8. 微信小程序授权登录流程

    https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html     微信小程序官方API 说明 ...

  9. 小程序微信授权登录服务器异常,微信小程序授权登录流程(强制绑定手机号码)...

    本文作为多平台用户登录模块设计的扩展设计,即以手机号作为用户的唯一凭证. (图片摘自 2018.10.30) 小程序与服务器是通过自定义登录态来识别用户身份的,以下简称口令(token). 由于微信未 ...

  10. uniapp微信小程序授权登录流程(代码直接复制可用)

    1.写一个点击登录的按钮 <view @tap="login">一键登录</view> 2.写点击事件 login() {wx.getUserInfo({s ...

最新文章

  1. 35 w年薪,入职CV算法岗,我一个双非本科生如何做到的?
  2. 安全设置之修改远程桌面连接默认3389端口
  3. 企业网络推广之下的“盒马鲜生”新零售逐渐“破圈”而出
  4. 在ubuntu系统荣品开发配套JDK安装
  5. win10电脑去掉快捷箭头_【搞机作战室】Win10系统电脑 常用快捷方式按键 (快捷键)介绍...
  6. hutool中的threadutil_Hutool - 好用的Java工具类库
  7. uniapp连接php,thinkphp5 对接手机uni-app的unipush推送(个推)
  8. 【原创】Ajax的用法总结
  9. C++中的floor()函数
  10. 简单了解https加密过程
  11. 计算机底层第一课,早学早受益
  12. python实现给定一个列表判断里面是否有重复元素
  13. java孢子进化_孢子进化论游戏
  14. opencv安装命令行
  15. 业务中台--如何设计企业级权限管理系统
  16. Android知识点深究
  17. XML保存衣服尺码信息
  18. 抖音直播新号怎么起号?抖音直播间不进人怎么办?
  19. 工欲善其事,必先利其器-器
  20. 飞凌单片机解密_GX28E01单片机解密

热门文章

  1. Ti-Click:通过浏览器快速搭建 TiDB 在线实验室 | Ti-可立刻团队访谈
  2. Second season seventeenth episode,Chandler gets a new roommate
  3. 移动端登录后,携带token请求其他页面接口提示token验证失败
  4. @Qualifier注解 的理解和使用
  5. 394高校毕业设计选题
  6. Java生成文本水印
  7. pytorch 使用netron可视化
  8. 矩阵求导术(二)——矩阵对矩阵的求导
  9. 多源异构传感器时空校准
  10. HyperAttentionDTI: improving drug–protein interaction prediction by sequence-based deep learning wit