spring+SpringMVC+Mybatise实现用户登录后挤掉前面的用户
来源:互联网 发布:java 工程师 简历 编辑:程序博客网 时间:2024/05/19 00:08
一、问题引导
在Web开发中,实现一个账号只能在一处登陆有两种形式:1.当某个账号在某处登陆后,如果再在其他处登陆,将前一个账号挤掉;2.当某个账号登陆后,此账号在其他设备登陆提示已经登陆,无法登陆。 正常的应用逻辑第一种应用较为广泛,因此此篇文章讨论一下第一种逻辑在spring mvc开发中一种较为简单的实现方式。
然而在没有长连接如WebSocket或者异步请求轮询的情况下,我们之前登陆的账号只能在下一次请求(同步或异步)才能获取被挤掉的状态(如页面跳转)。
二、实现步骤
1.建立一个静态Map,用来存放账号和sessionID的对应关系
2.在登陆时,校验Map中是否已存在此账号,如果不存在说明是第一次登陆,将账号和sessionID的对应关系存放到静态Map中;如果Map中存在此账号,并且sessionID和本次请求的sessionID不一致,将Map中的sessionID替换掉,因此之前登陆的账户在发送下一次非登录和校验的请求会被拦截。
3.创建拦截器,拦截除登陆和校验url以外的所有请求。判断请求的sessionID和静态Map中此账户对应的sessionID是否一致。如果不一致,跳转到登陆页面。
三、实现代码
1.创建一个内存数据类,用于存放静态的数据,并初始化:
2.创建Controller,实现校验登陆用户
3.创建拦截器
4.在springmvc.xml配置文件中添加拦截器
四、后续
此种方式实现一个账号只能在一处登陆是一种较简单的方法,当然也可以通过移除session的方式实现。本文皆由本人亲测实现,如有错误,欢迎指正。
阅读全文
0 0
- spring+SpringMVC+Mybatise实现用户登录后挤掉前面的用户
- JSP+SERVLET实现后登陆用户挤掉之前登录用户
- j2ee实现强行挤掉重复登录用户
- java web相同用户重复登陆,即用户唯一登录,后登陆挤掉先登录的,设置限制用户同时登陆人数
- springmvc+shiro用户登录后获取用户
- Asp.net项目同一个用户后登录把前面登录的踢下线的两种实现方法
- SpringMVC实现用户登录实例
- spring security3 记录用户登录成功后的登录时间
- springmvc拦截器实现对用户登录状态的判断
- springmvc 自定义拦截器实现未登录用户的拦截
- 用户重复登录问题(类似QQ),第二次登录强行挤掉第一个用户。
- SpringMVC + Mybatis 实现用户登录功能
- maven+springMVC+jdbc实现用户登录
- springmvc控制登录用户session失效后跳转登录页面
- springmvc控制登录用户session失效后跳转登录页面
- 不用用户使用同一用户名登陆,挤掉前面那个人(Session,Listen)
- spring security(七) session 并发,一个用户在线后其他的设备登录此用户失败
- springmvc用户登录信息
- Error:(30, 13) Failed to resolve: com.github.bumptech.glide:glide:3.7.0
- 颜色代码大全
- 微信小程序,时间戳转为日期格式
- Bootstrap DateTimePicker选择月份BUG
- OpenGL ES应用开发实践指南(android 卷)笔记 第二章1
- spring+SpringMVC+Mybatise实现用户登录后挤掉前面的用户
- 数据库设计(一)
- 去掉超链接或按钮点击时出现的虚线边框
- Virustotal——md5转sha256
- 安卓自定义 View 进阶:Path 完结篇
- mysql中log-bin日志设置
- mysql处理海量数据时的一些优化查询速度方法
- 2017年多校赛第一场 1001 Add More Zero(逻辑思维)
- String、StringBuilder和StringBuffer的区别