如何用php实现一个账号不能多个用户同时登陆?
回复内容:
修改 要求:当某个账号登陆后,其它用户再登录该账号!当前账号就会被强制下线,就类似qq异常登录那样子!大神们给个具体实现思路??
生成个token存在数据库,写入session。操作的时候 把session的token和数据库对比,不一样则logout.
"其它用户再登录该账号!当前账号就会被强制下线"
这里是你要及时的,还是刷新(再次发送http请求)之后。
前者需要一个类似socket的长连接,或者用心跳包。
接下来或者后者的操作,@xfspace也说的比较清楚了。
每次登录生成一个随机token用于验证cookie.
不同的登录生成的token也不同,自然之前生成的cookie都会失效.
不过需要注意的是,如果用户把cookie直接复制并注入到局域网里的另一台电脑的浏览器里使用,服务器那边不好辨别.
哪有那么麻烦啊。
1.新建一个 token表。
字段:token(令牌,一般8个随机字符串就可以了),uid(本站用户ID),expiresIn(过期时间)
用户登录成功的时候插入一条记录,并把以前该用户的所有token数据过期或者删除,这样就可以保证同一时间只有一个有效的token起作用,起到了不能重复登录的作用。
上一篇: 如何用PHP实现表单提交?
下一篇: 有关get请求的实例教程