解决的思路是每当用户登陆时我们必需记录当前的用户id和session_id,如果有人在其它地方用此账号登陆时,我们把此用户id对应的session_id的session文件删除,并重新记录当前的session_id。那么之前的用户就失效了。 db.php代码如下: tb_login_state表结构如下:
login.php代码如下:
$uname ); echo ''; echo ''; }}?>用户登陆页面
index.php代码如下:
CREATE TABLE `tb_login_state` (`uid` int(11) unsigned NOT NULL COMMENT '用户ID',`session_id` varchar(32) NOT NULL DEFAULT '' COMMENT '存储用户的session_id') ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用户登陆状态表';
如果是session存储方式不是文件,而是存在mysql,memcache,redis中,思路其实是一样的,都是把前一次的session_id保存。判断用户是否登陆过,如果登陆过就让上一次的session失效(删除session数据)。
(*通过设置session的过期时间和cookie的过期时间来让session失效是不严格的,最直接的方法是直接把session文件删除。)
推荐阅读:
http://www.laruence.com/2012/01/10/2469.html