一般的原则就是,后一个用户登录时会把前一个用户踢下线。
在用户首次登录时,我们会把用户的sessionid保存到数据库,这个是用户的唯一标识。方便后边操作。
用户只有在登录时才会和数据库中的phpsessid进行对比,如果不同,则更新数据库中的phpsessionid为当前浏览器的phpsessionid,这样后登录的用户就把前边登录的用户给踢下线了。
但是前边的用户怎么知道自己被踢下线了?
我使用的Yii框架,在YII框架中有一个filters()这样一个方法。在每个控制器中都存在该方法,我们可以在这个方法中,让当前用户的phpsessionid与数据库中的phpsessionid进行验证,当发现phpsessionid不同时,我们就清除当前浏览器的phpsessionid,并退出网站,提醒用户当前帐号在其他地方登陆。