[手机大魔王]简单解析一下扫码登陆原理
前言
【[手机大魔王]简单解析一下扫码登陆原理】随着wx的普及对开发同学来说一些业务场景会使用到“扫码登录”功能 , 特别是PC网页端 , 在此之前没有这方面的开发经历 , 所以接到这个需求的时候还是有点慌的 , 最终通过查阅网上的资料以及老大的指导下实现了这个功能 , 目前已经投入使用 , 实现之后还是蛮兴奋的 。 特此记录一下实现的过程 。
原理解析
扫码登陆的实现需要手机端的服务器和Web端的服务器配合实现 。 大致分为以下几步:
step1:网页端请求登陆二维码
本文插图
要实现网页版的扫码登陆 , 用户必须先要请求一个登陆的二维码 。 Web端的服务器收到用户申请登陆二维码的请求后 , 会随机生成一个uuid(这个uuid作为页面的唯一标识符) , 并且会将这个uuid当做一个键值对的key存入后台Redis 。 存入Redis的这个键值对的value是什么我们待会再说 。
需要注意的是存入Redis的键值对必须设置一个过期时间 , 不然的话拿着这个uuid登陆一次后就一直处于登陆状态了 。
当浏览器端拿到Web服务端返回的二维码信息后 , 解析其中的uuid , 并拿这个uuid不断去后台轮询是否已经登陆成功 。 如果后台已经登陆成功 , Web端就自动跳转到登陆成功页面 。 不然的话会一直轮询 , 直到二维码失效(这里我们发现给二维码设置有效时间真的很有必要 , 如果二维码没有有效时间的话 , 会不断的轮询后台 , 给后台造成很大的压力) 。
那么上面的关键点是Web端服务器是怎么判断用户是否已经扫码登陆成功过的呢? 请看下面的步骤 。
step2:手机端将用户id存入Redis
本文插图
手机端服务器会先拿token信息判断这个用户是否合法 , 是否已经正常登陆 。 如果判断已经正常登陆 , 那么会将这个用户的userId和提交过来的uuid当做一个键值对(uudi-userId)存入Redis 。 这边回答了步骤一种留下的问题 。
简单来讲手机端做的工作就这么多 。 让我们继续回到Web端 。
step3:web端轮询成功
本文插图
步骤一中讲到:二维码登陆页会不停的轮询是否登陆成功 。 这边的依据就是Redis中存在uuid-userId键值对 。 如果这个键值对已经存在 , 说明手机端已经扫码登陆过 。
Web端服务器一旦判断到手机端已经扫码登陆过 , 就可以拿着userId进行登陆 。 并将必要的用户信息和token信息返回Web前端 。 至此Web端登陆成功 。
简单总结
本文记录了一个扫码登陆的简单版本 , 但是也能描述扫码登陆的大致原理 。 实际开发过程中应该还是有许多细节需要考虑 。 比如安全问题等 。 具体的还是需要我们进行实战了 。
欢迎大家一起讨论~
作者: 写代码的木公
- 11还记得母亲节?送一台千元以下的手机真暖心,百善孝为先
- 一片唱衰的魅族17系列,还有希望吗?
- 企业与观察华为如果上市估值将达13000亿美元!揭秘国民手机为何不上市?
- 长旭数码华为三款值得买的5G手机,不同价位,入手正当时
- 军军说娱乐MP3被手机淘汰了?其实它们比你想象中,更受人欢迎
- 阿冰说手机考虑了好久,换什么手机(4k左右)?
- 旗舰安兔兔3000元以上手机性价比排行公布:realme X50 Pro夺冠
- 玩懂手机原创 LG Stylo 6渲染图曝光:后置横向三摄+手写笔
- IT数码通你现在使用哪款手机?你是否支持国产手机?
- 手机中国全新体验3699元起,魅族17系列今天10点全渠道开售