php单用户登录

原理:同一账号在多个设备上登录,前者被后者顶下线;假设账号在设备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{
   # 不存在用户信息逻辑处理(跳转到登录界面)
}

原文:添加链接描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值