运用session来控制用户的异地登录被挤下线情况

    在用QQ的过程中我们如果你的账号在另外一台手机上面登录,这是腾讯后台会提醒你异地登录,可能你的账号被盗了,然后你手机上得QQ就会被退出登录,这个时候你就需要重新登录修改密码,以确保账号的安全。那这种被挤下线的行为其实很普遍,我接触过的每个项目几乎都用到过,就是用session来实现,应为每个设备的session不一样,服务端就根据你上传来的session来判断是不是同一台设备登录。

    首先,登录的时候,我们会将用户的信息,还有session存起来,直接看代码(php实现):

     public function setUserToSessin($user){

       $user_key = "user_"+$user['id'];

         $session_key = $this->getCacheSessionKey('user');

       $old_session_key = $this->getCacheSessionKey('user',Cache:get($user_key,null));

       if($old_session_key && strcmp($old_session_key,$session_key) !== 0){

        Cache:forget($old_session_key);

        }

       Cache::put($user_key,Session::getId(),2147483647);

       Cache::put($session_key,$user,2147483647);

      }

     private function getCacheSessionKey($key,$session_id=null){

      $session_id = $session_id ? $session_id : Session:getId();

      $session_key = sprintf('%s_session_%s',$key,$session_id);

      return $session_key;

         }

     public function getUserFromSession(){

       $session_key = $this->getCacheSessionKey('user');

       $user = Cache::get($session_key,null);

       if(!$user){

        return new UserNotLoginException;

       }

       return $user;

     }

 
原文地址:https://www.cnblogs.com/maoaji/p/5917906.html