spring mvc实现登录账号单浏览器登录
作者:Mr_Smile2014 时间:2022-06-28 22:29:47
在很多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>
标签:spring,mvc,登录,浏览器
0
投稿
猜你喜欢
Java线程池Executor用法详解
2022-02-13 01:21:16
配置Ant执行Jmeter脚本过程详解
2023-11-09 22:35:29
Java8 使用工厂方法supplyAsync创建CompletableFuture实例
2023-02-14 03:57:22
Flutter开发中的路由参数处理
2023-06-21 04:27:48
java链式创建json对象的实现
2023-11-12 12:36:51
一文带你了解C#中抽象方法与虚方法的区别
2023-07-23 00:14:32
Java设计模式之工厂模式实现方法详解
2023-11-26 07:55:51
Java集合定义与用法实例总结【Set、List与Map】
2023-11-21 08:26:40
Java使用Redisson分布式锁实现原理
2023-12-10 11:07:30
Idea配置Maven阿里云镜像加速的实现
2021-10-24 11:30:32
nacos使用占位符${}进行参数配置的方法
2022-07-15 08:59:07
java多次嵌套循环查询数据库导致代码中数据处理慢的解决
2023-10-28 22:17:50
Java基础学习之关键字和变量数据类型的那些事
2023-09-17 04:31:24
如何解决java压缩文件乱码问题
2022-05-20 09:15:57
Android 动画之TranslateAnimation应用详解
2023-06-27 06:17:59
Java ArrayList类的基础使用讲解
2021-11-14 10:22:18
Spring boot集成Kafka消息中间件代码实例
2022-11-06 21:53:48
redis统计APP在线人数的实例
2023-11-24 23:56:54
springboot集成开发实现商场秒杀功能
2022-06-23 11:05:27
SpringBoot自动配置深入探究实现原理
2023-08-06 09:59:58