共计 1022 个字符,预计需要花费 3 分钟才能阅读完成。
原理:同一账号在多个设施上登录,前者被后者顶下线;假如账号在设施 A 登录,该账号又在设施 B 登录,此时设施 A 登录的账号被顶下线
思路剖析
1、用户登录胜利后将以后工夫存入 session 中,以及制作个 token 值存入该用户数据库中;
2、在验证用户是否登录的模块中,若用户已登录,将用户数据库中的 token 取出,并且制作一个最新的 token,两者判断是否相等,若不相等,用户下线;
代码实现
1、在登录胜利的代码模块下操作;
// 登录验证
$user = DB::table('user')->where(['username' => 账号, 'password' => 明码])->first();
if ($user) {
# 登录胜利
$time = time();
$token = md5($user['id'].$time); // 制作 token 用 md5 加密
DB::table('user')->where(['id'=>$user['id']])->update(['token' => $token]);// 将 token 存入以后用户数据中
session(['token_time'=>$time]);// 将以后工夫存入 session 中
session(['user'=>$user]);// 将用户信息存入 session 中
} else {# 登录失败逻辑解决}
2、在判断用户是否曾经登录的代码模块下操作;
$userInfo = session('user');// 从 session 中获取用户信息
if ($userInfo) {
# 存在用户信息
$token_time = session('token_time');// 从 session 中获取 time
$last_token = md5($userInfo['id'].$token_time);// 制作以后的 token 值
$token=DB::table('user')->where('id', $userInfo['id'])->value('token');// 获取该用户数据中的 token
if($last_token!=$token){
// 若以后的 token 值与数据中的 token 值不相等,则将用户信息清空,用户被顶下线
$userInfo=null;
}
}else{# 不存在用户信息逻辑解决(跳转到登录界面)}
最初
感觉文章不错的,给我点个赞哇,关注一下呗!
技术交换可关注微信公众号【GitWeb】,加我好友一起探讨
微信交换群:加好友(备注思否)邀你入群,抱团学习共提高
正文完