shiro实现单点登录(一个用户同一时刻只能在一个地方登录)

作者:mrr 时间:2022-07-04 01:37:55 

我这里 shiro 并没有集成 springMVC,直接使用 ini 配置文件。

shiro.ini


[main]
# Objects and their properties are defined here,
# Such as the securityManager, Realms and anything
# else needed to build the SecurityManager
authc.loginUrl = /login.jsp
authc.successUrl = /web/index.jsp
#cache manager
builtInCacheManager = org.apache.shiro.cache.MemoryConstrainedCacheManager
securityManager=org.apache.shiro.web.mgt.DefaultWebSecurityManager
securityManager.cacheManager = $builtInCacheManager
securityManager.sessionManager=$sessionManager
#session 必须配置session,强制退出时,通过将session移除实现
sessionManager=org.apache.shiro.web.session.mgt.DefaultWebSessionManager
sessionManager.sessionDAO=$sessionDAO
sessionDAO=org.apache.shiro.session.mgt.eis.MemorySessionDAO
# Create ldap realm
ldapRealm = org.apache.shiro.realm.ldap.JndiLdapRealm
#......
# Configure JDBC realm datasource
dataSource = org.postgresql.ds.PGPoolingDataSource
#.......
# Create JDBC realm.
jdbcRealm.permissionsLookupEnabled = true
jdbcRealm = org.apache.shiro.realm.jdbc.JdbcRealm
jdbcRealm.userRolesQuery = ......
jdbcRealm.permissionsQuery = ......
jdbcRealm.dataSource = $dataSource
#self realm
localAuthorizingRealm = com.redbudtek.shiro.LocalAuthorizingRealm
securityManager.realms = $ldapRealm, $localAuthorizingRealm

在 LocalAuthorizingRealm 中,用户登录进行认证之前,先将该用户的其他session移除:


@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken authenticationToken) throws AuthenticationException {
String userName = (String)authenticationToken.getPrincipal();
//处理session
DefaultWebSecurityManager securityManager = (DefaultWebSecurityManager) SecurityUtils.getSecurityManager();
DefaultWebSessionManager sessionManager = (DefaultWebSessionManager)securityManager.getSessionManager();
Collection<Session> sessions = sessionManager.getSessionDAO().getActiveSessions();//获取当前已登录的用户session列表
for(Session session:sessions){
//清除该用户以前登录时保存的session
if(userName.equals(String.valueOf(session.getAttribute(DefaultSubjectContext.PRINCIPALS_SESSION_KEY)))) {
sessionManager.getSessionDAO().delete(session);
}
}
String pwd = null;
return new SimpleAuthenticationInfo(userName,pwd,getName());
}

shiro实现单点登录(一个用户同一时刻只能在一个地方登录)

当session删除之后,必须有客户端与服务器端的交互,shiro才能进行认证判断。在与服务器交互时,subject信息截图如下:

shiro实现单点登录(一个用户同一时刻只能在一个地方登录)

此时的登录的用户认证已经失效,可以对客户端做出响应。

以上所述是小编给大家介绍的shiro实现单点登录(一个用户同一时刻只能在一个地方登录)网站的支持!

标签:shiro,单点,登录
0
投稿

猜你喜欢

  • SpringBoot通过自定义注解实现参数校验

    2023-09-21 21:11:02
  • 浅谈Java中方法参数传递的问题

    2021-11-06 04:24:46
  • MyBatis核心源码深度剖析SQL语句执行过程

    2022-11-09 01:05:39
  • Java调取创蓝253短信验证码的实现代码

    2021-11-05 00:48:10
  • 测试springboot项目出现Test Ignored的解决

    2022-06-25 08:37:02
  • 一文详解Jetpack Android新一代导航管理Navigation

    2022-12-08 20:40:14
  • Spring Security短信验证码实现详解

    2023-07-04 22:27:07
  • java 动态增加定时任务示例

    2023-07-29 06:56:00
  • 基于FeignException$InternalServerError的解决方案

    2023-04-25 15:50:45
  • android UI绘制加减号按钮

    2023-09-11 02:55:28
  • 关于MyBatis plus条件构造器的逐条详解

    2021-10-06 07:31:51
  • Java并发编程之CountDownLatch源码解析

    2023-11-05 02:06:41
  • Java字符流与字节流区别与用法分析

    2023-09-08 07:48:54
  • Android下拉列表选项框及指示箭头动画

    2022-09-28 04:08:15
  • Java计时新姿势StopWatch的使用方法详解

    2022-01-28 00:49:57
  • C#动态执行批处理命令的方法

    2023-03-16 23:19:40
  • java中文传值乱码问题的解决方法

    2023-11-25 16:26:47
  • C# 枚举Color并展示各种颜色效果的示例

    2023-10-24 21:27:27
  • Java基础篇之反射机制示例详解

    2021-12-08 04:05:25
  • Mybatis中where标签与if标签结合使用详细说明

    2021-07-27 08:15:53
  • asp之家 软件编程 m.aspxhome.com