问题概述:由于一个账户只能同时登陆一次,意在不能多个用户不能同时登陆一个账户,所以需要对账户登陆与退出进行检测。这个问题可以在数据库增加一个登陆状态字段。每次登陆时进行判断即可,但是当遇到异常退出系统(关机,关闭网页等),没有走正常退出的路由,即没有执行更改登陆状态的操作,这个办法就有些欠妥了。
问题解决:
1.超时退出:在symfony2中可以在配置文件 config.yml 中设置超时时间限制,会刷新退出系统。
framework: #esi: ~ translator: { fallbacks: [zh_CN] } # ...... session: # http://symfony.com/doc/current/reference/configuration/framework.html#handler-id handler_id: session.handler.native_file save_path: "%kernel.root_dir%/../var/sessions/%kernel.environment%" cookie_lifetime: 1800 // 30分钟无操作自动退出
2.异常退出:解决办法是登录状态字段不仅存一个数字代表状态,还要存一个时间字段,用自定义分隔符隔开。然后需要在index,js中写一个定时器,定时向指定路由发送数据包,该路由执行的就是对数据库登录字段的写操作,定时刷新时间。当有其他用户登录已登录账户、上次异常退出账户及已超时退出账户、正常退出账户时,只需要对登录字段的状态和时间进行判断。获取当前时间与该时间做差,比较时间是否超过定时器的间隔时间的整数倍(1、2..),即可。
隐患问题是:在他人异常退出后,可能需要再次正常登录该账号需要一个时间差,不是可以立即登录,因为可能需要上文设置的等待时间间隔(最长等待时间为上文的时间间隔)。