前后端分离情况下实现二维码登录思路
1.PC页面程序生成登录二维码,二维码中包含一个uuid标识唯一,返回二维码到PC页面,同时PC页面监听后台登录成功信息
2.手机扫描二维码获取uuid同事获取手机已经登录的用户信息调用后台接口写入公共用户数据池里
3.PC监听程序监听到后台数据池登录成功。
4.获取登录信息调用登录接口 登录完成时跳转首页。
package com.example.login.biz;
import com.example.login.common.UserContext;
import com.example.login.entity.User;
import javafx.util.Pair;
import java.util.UUID;
/**
* 二维码登录
* 用戶登录业务类
*/
public class UserLoginBizService {
/**
* :0:App登录
*
* @param user
* @return
*/
public Pair<Boolean, User> appLogin(User user) {
//伪代码 校验合法性
User user_ = new User();
user_.setMobile("18322345467");
user_.setPassword("123456");
//登录成功
return new Pair<>(true, user_);
}
/**
* 4:Web后台登录
*
* @param user
* @return
*/
public Pair<Boolean, User> webLogin(User user) {
return appLogin(user);
}
/**
* 1:生成登录二维码 返回二维码图片地址
* <p>
* 手机端调用appScanCodeLogin
*
* @return
*/
public String generateLoginQRCode() {
String uuid = UUID.randomUUID().toString().replace("-", "");
//生成二维码图片 图片内容 uuid
String imgUrl = new String("xxxxx");
return imgUrl;
}
/**
* 3:web 也面渲染二维码图片的同时轮训监听这个接口 登录成功返回true 否则false
* 返回成功调用登录接口登录
*
* @param uid
* @return
*/
public Pair<Boolean, Object> checkWebLoginStatus(String uid) {
User user = UserContext.userMap.get(uid);
if (user != null) {
UserContext.userMap.remove(uid);
return new Pair<>(true, user);
}
return new Pair<>(false, "未登录");
}
/**
* 2:手机扫码登录 获取uid 根据已登录用户信息 写入用户名密码 uid 保存到服务端用户上下文中
*
* @param user
* @return
*/
public Pair<Boolean, Object> appScanCodeLogin(User user) {
String uid = user.getUid();
if (uid != null && uid != "") {
//放用户信息到上下文
UserContext.userMap.put(uid, user);
return new Pair<>(true, "操作成功");
}
return new Pair<>(false, "登录信息不完整");
}
}