自己想的,或许不是很好,以后有时间了慢慢考虑。
1.通过在数据库表里设置字段。比如用户登录,有个登陆次数字段,用户登陆前先判断账号是否
在别处登陆。若登陆,那么登陆次数+1,另一个用户在登陆后的任何操作前,需要加个过滤器,
用于从数据库取出登陆次数与第一次登陆时对比,若增加,说明有人重复登陆,自己强制下线。
但这种方式,用到过滤器会频繁的访问数据库。
2.通过监听器来对每一个session进行监听,每隔一段时间监听一次。若发现,不同session中存
有相同用户名,则下线,但这样会出现一个问题,就是在监听期间,会存在2用户同时登陆的情况
。
3.通过jsp内置对象application进行绑定信息,把用户名登陆次数以map形式存放在application
中,application作用域是整个服务器开启到关闭之间,所以一个用户登陆后,可以通过查找map
的key来判断是否有用户已经登陆,若有,则让value+1,登陆过的用户,每次操作前查对应的
value,若改变则强制下线。这样就解决了上面2个问题。不过以前好像听老师说最好不要在
application中存放数据,以后有时间再解决吧。
1.通过在数据库表里设置字段。比如用户登录,有个登陆次数字段,用户登陆前先判断账号是否
在别处登陆。若登陆,那么登陆次数+1,另一个用户在登陆后的任何操作前,需要加个过滤器,
用于从数据库取出登陆次数与第一次登陆时对比,若增加,说明有人重复登陆,自己强制下线。
但这种方式,用到过滤器会频繁的访问数据库。
2.通过监听器来对每一个session进行监听,每隔一段时间监听一次。若发现,不同session中存
有相同用户名,则下线,但这样会出现一个问题,就是在监听期间,会存在2用户同时登陆的情况
。
3.通过jsp内置对象application进行绑定信息,把用户名登陆次数以map形式存放在application
中,application作用域是整个服务器开启到关闭之间,所以一个用户登陆后,可以通过查找map
的key来判断是否有用户已经登陆,若有,则让value+1,登陆过的用户,每次操作前查对应的
value,若改变则强制下线。这样就解决了上面2个问题。不过以前好像听老师说最好不要在
application中存放数据,以后有时间再解决吧。