当前位置: 移动技术网 > IT编程>开发语言>Java > spring mvc实现登录账号单浏览器登录

spring mvc实现登录账号单浏览器登录

2019年07月22日  | 移动技术网IT编程  | 我要评论

在很多web产品中都需要实现在同一时刻,只能允许一个账号同时只能在一个浏览器当中登录。通俗点讲就是当a账号在浏览器1当中登录了,此时在浏览器2中登录a账号。那么在浏览器1中的a账号将会被挤出去,当用户操作浏览器1的页面,页面会跳到登录页面,需要重新登录。那么我们怎么实现这样的功能呢?下面将给大家进行详细的介绍:

原理

用户a使用账号a在浏览器当中登录,然后用户b在另外一台电脑上的浏览器登录账号a,当用户b登录验证成功时,将会触发登录监听类,在监听类当中判断出账号a已经被用户a登录,就把用户a的账号a 踢出去,此时当用户a操作页面,页面就会跳转到登录页面。

代码实现

在实现过程中,用到loginlistenner监听类、login登录方法以及在web.xml中配置监听类

loginlistenner

当登录成功后,向session中放入登录成功的账号对象loginuser,触发loginlistenner中的attributeadded事件,在这个事件中,我们判断存放账号和session对应关系的map中是否有当前登录的账号的session,如果有我们就把该session从map中移除,同时注销该session,然后把刚登录的账号和session放入map。下面是代码:

/** 
 * 
 * @classname: loginlistenner 
 * @description: 登录监听类-处理同一时间只允许账号,单地点登录 
 * @author mr_smile2014 605051929@qq.com 
 * @date 2014年11月12日 下午2:23:41 
 * 
 */ 
public class loginlistenner implements httpsessionattributelistener { 
 /** 
 * 用于存放账号和session对应关系的map 
 */ 
 private map<string, httpsession> map = new hashmap<string, httpsession>(); 
 
 /** 
 * 当向session中放入数据触发 
 */ 
 public void attributeadded(httpsessionbindingevent event) { 
 string name = event.getname(); 
 
 if (name.equals("loginuser")) { 
  user user = (user) event.getvalue(); 
  if (map.get(user.getusername()) != null) { 
  httpsession session = map.get(user.getusername()); 
  session.removeattribute(user.getusername()); 
  session.invalidate(); 
  } 
  map.put(user.getusername(), event.getsession()); 
 } 
 
 } 
 /** 
 * 当向session中移除数据触发 
 */ 
 public void attributeremoved(httpsessionbindingevent event) { 
 string name = event.getname(); 
 
 if (name.equals("loginuser")) { 
  user user = (user) event.getvalue(); 
  map.remove(user.getusername()); 
 
 } 
 } 
 
 public void attributereplaced(httpsessionbindingevent event) { 
 
 } 
 
 public map<string, httpsession> getmap() { 
 return map; 
 } 
 
 public void setmap(map<string, httpsession> map) { 
 this.map = map; 
 } 
 
} 

登录方法

对账号、密码、验证码进行判断和验证,验证通过后把对应的用户对象放入到session中,代码如下:

/** 
 * 登录 
 * 
 * @param username 
 * @param password 
 * @param code 
 *  验证码 
 * @param type 
 *  登陆类型(商户,操作员) 
 * @param model 
 * @return 
 */ 
 @requestmapping("/login") 
 public string login(string account, string password, string code, 
  model model, httpservletrequest request) { 
  //登录验证并返回登录成功用户对象 
  user user=loginresult(userphone, password, code, request); 
  //把用户对象放入到session中,将会触发loginlistenner中的attributeadded事件 
  request.getsession().setattribute("loginuser", user); 
  
  } 

web.xml配置

把loginlistenner监听类,配置到web.xml文件中,这样对session的监听才生效。配置如下:

<!--一个用户只能在一个主机登录 --> 
 <listener> 
 <listener-class>com.test.listenner.loginlistenner</listener-class> 
</listener> 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网