扫码登录的典型流程图
关于扫码登录,之前写过几篇文章以及发过相关的视频。
@startuml
autonumber
actor "用户" as User
participant "浏览器" as Browser
participant "手机端" as Mobile
participant "服务端" as Server #orange
activate User
User -> Browser: 输入 URL
activate Browser
Browser -> Server: 请求 csrf token
activate Server
Server -> Browser: 返回 csrf token
deactivate Server
Browser -> Server: 带上 csrf token 请求生成二维码
activate Server
Browser -> Server: 开始轮询二维码的状态
Server -> Server: 生成二维码
note right of Server: 并记录该二维码的状态是等待扫描
Server -> Browser: 返回待扫描
Server -> Browser: 返回二维码
deactivate Server
Browser --> User
User -> Mobile: 进入 APP,点击扫码
activate Mobile
Mobile -> Server: 通知已扫描
activate Server
Server -> Server: 更新二维码状态为已扫描
deactivate Server
Mobile -> Mobile: 展示确认登录页面
Mobile --> User
deactivate Mobile
Browser -> Server: 轮询二维码状态
activate Server
Server -> Browser: 返回已扫描,等待确认
Browser -> Browser: 更新 UI,显示已扫描
Browser --> User
deactivate Server
User -> Mobile: 点击确认登录
activate Mobile
activate Server
Mobile -> Server: 通知二维码的状态为已确认
Server -> Mobile: 通知用户已登录
deactivate Mobile
Server -> Server: 更新二维码的状态为已确认
deactivate Server
Browser -> Server : 轮询二维码状态
activate Server
Server -> Browser: 返回已确认,并带上用户登录 cookie
Browser -> Browser: 更新 cookie
Browser -> Server: 使用 cookie 请求用户信息
Server -> Browser: 返回用户信息
Browser -> Browser: 存储用户信息到 local storage
Browser --> User: 展示用户登录态页面
@enduml
@startuml
autonumber
actor "用户" as User
participant "浏览器" as Browser
participant "手机端" as Mobile
participant "服务端" as Server #orange
activate User
User -> Browser: 输入 URL
activate Browser
Browser -> Server: 请求 csrf token
activate Server
Server -> Browser: 返回 csrf token
deactivate Server
Browser -> Server: 带上 csrf token 请求生成二维码
activate Server
Browser -> Server: 开始轮询二维码的状态
Server -> Server: 生成二维码
note right of Server: 并记录该二维码的状态是等待扫描
Server -> Browser: 返回待扫描
Server -> Browser: 返回二维码
deactivate Server
Browser --> User
User -> Mobile: 进入 APP,点击扫码
activate Mobile
Mobile -> Server: 通知已扫描
activate Server
Server -> Server: 更新二维码状态为已扫描
deactivate Server
Mobile -> Mobile: 展示确认登录页面
Mobile --> User
deactivate Mobile
Browser -> Server: 轮询二维码状态
activate Server
Server -> Browser: 返回已扫描,等待确认
Browser -> Browser: 更新 UI,显示已扫描
Browser --> User
deactivate Server
deactivate User
Browser -> Server: 轮询二维码状态
activate Server
Server -> Browser: 返回已扫描,待确认
deactivate Server
deactivate Browser
...
Server -> Server: 超时,更新二维码状态为超时
Browser -> Server: 轮询二维码状态
activate Browser
activate Server
Server -> Browser: 返回已超时
Browser -> Browser: 进入刷新二维码流程
@enduml
图片源码如下:
[*] --> 已生成
已生成 --> 已超时 : 超时未扫码
已生成 : 等待用户扫码
已生成 -> 已扫码 : 用户扫码
已扫码 : 等待用户点击确认
已扫码 -> 已确认: 用户点击确认
已确认 : 创建 session,进入登录态
已扫码 --> 已超时: 超时未确认
已确认 -> [*] : 服务器端可以删除二维码状态存储了
已超时 -> [*] : 服务器端可以删除二维码状态存储了
若有收获,就点个赞吧
评论