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

网友投稿 257 2023-05-21


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

在很多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。下面是代HtDJFZwB码:

/**

*

* @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 map = new HashMap();

/**

* 当向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 getMap() {

return map;

}

public void shttp://etMap(Map 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的监听才生效。配置如下:

com.test.listenner.LoginListenner

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


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:详解Angular中的自定义服务Service、Provider以及Factory
下一篇:vue+vuex+axio从后台获取数据存入vuex实现组件之间共享数据
相关文章

 发表评论

暂时没有评论,来抢沙发吧~