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

我这里 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());
}

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

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

以上所述是小编给大家介绍的shiro实现单点登录(一个用户同一时刻只能在一个地方登录),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索shiro实现单点登录
shiro实现单点登录、shiro 单点登录、shiro单点登录实例、shiro cas 单点登录、shiro sso单点登录,以便于您获取更多的相关知识。

时间: 2024-09-15 09:13:12

shiro实现单点登录(一个用户同一时刻只能在一个地方登录)_java的相关文章

怎么判断2个相同登录的账号,在不同计算机上登录,让另一个下线的功能。

问题描述 怎么判断2个相同登录的账号,在不同计算机上登录,让另一个下线的功能. 解决方案 解决方案二:IP+用户名+在线状态解决方案三:你了解单点登录的知识就懂了解决方案四:直接用get就行了吧解决方案五:1.给每次登陆的用户随机生成一个唯一的登陆ID,并记录下它的登陆IP:2.如果第二次登陆IP,不同于上一次,把上一次的登陆ID设置为失效:3.用户每次访问,先验证其登陆ID是否有效,如果无效,就让它下线,删掉它的session.解决方案六:请研究单点登录解决方案七:只能在一个地点登录,这跟SS

java-关于CAS单点登录的用户认证

问题描述 关于CAS单点登录的用户认证 现有多个系统web1,web2,web3... 用户张三,在web1里用户名密码是user1/123,在web2里用户名密码是zhangsan/456,在web3里用户名密码是abc/789-- 这些多个系统的用户名密码存放在不同数据库中,但是每个数据库里都有"工号"这个字段,且为必填项. 现在将这多个系统用CAS做单点登录,这多个数据库如何通过"工号"这个字段统一? 刚看到的一个思路: 单对多模式:一个用户使用不同凭证登录不

技术-怎样实现一个用户登录系统呢?

问题描述 怎样实现一个用户登录系统呢? 我想实现一个用户登录页面已经实现了用户的注册了也写进了mysql中我也知道用户登陆的时候要去数据库里面查看有没有登录页面中输入的账号密码信息如果和数据库中的一致就进入成功的页面如果不符就进入错误页面.可是就是不知道怎么写应该用到什么技术呢? 解决方案 设计一个可扩展的用户登录系统设计一个可扩展的用户登录系统 解决方案二: http://www.51testing.com/html/88/377588-814420.html 解决方案三: 没什么技术吧获取输

C++开发系统开发的火车票订票系统里,管理员登录,用户登录是一个窗口的么?

问题描述 C++开发系统开发的火车票订票系统里,管理员登录,用户登录是一个窗口的么? C++开发系统开发的火车票订票系统里,管理员登录,用户登录是一个窗口的么? 解决方案 一个窗口足够了,不同的角色在你的后台判断,并且开放对应的功能. 解决方案二: 这个是自己设计的,想怎么样就怎么样. 解决方案三: 一个页面重复使用,只是换了不同请求ULR,

用vs2010做一个用户登录网页 访问本地的数据库

问题描述 http://zhidao.baidu.com/link?url=DJjq2sxXYkx1cRKIZC0QYwQyQcP9Fj8G8Edk1fXgF7ba13K_1-Nq0m6UXAd0mzVuKUXdtKkYH1w2unGVVdIY8_可以和这个类似但是要访问本地数据库菜鸟一只实在不会啊,先建立一个数据库UserTest.2,在里面建立一个表叫UsersTable,设计表,建立三个列:u_id,u_name,u_pwd.3,u_id是int数据类型,自增1:u_name是nvarch

如何实现一个页面在某一时刻只能被一个用户访问??

问题描述 如题,一个页面在某一时刻只能被一个用户访问,希望大家讨论提供点想法,谢谢! 解决方案 定义一个全局锁,比如Application或者其他全局可以访问的资源都行.注意线程安全.然后进去一个人就锁上,其他人访问就提示有人正在使用资源那个人退出或者掉线啥啥的就开放锁.解决方案二:能够检测用户进入,但如何检测用户转到其他页面呢?或者某用户打开这个页面后出去玩了 怎么办?这个功能是不是存在的意义不大解决方案三:moogle 写道:引用定义一个全局锁,比如Application或者其他全局可以访问

限制在同一台电脑上只允许有一个用户登录系统

在web应用系统中,出于安全性考虑,经常需要对同一客户端登录的用户数量和一个客户同时在多个客户端登陆进行限制.具体一点就是:    1.在同一台电脑上一次只允许有一个用户登录系统,2.一个用户在同一时间只允许在一个客户端登录.     我最近做的一个系统就遇到了这样的问题,本来系统已经开发完成了,但是安全测评没有通过,就是因为没有做这两个限制.怎么来做这样的限制呢?我在网上找了很久,发现问这个问题的人很多,但是没有找到特别清楚的答案.后来自己摸索着,看了一些书,终于找到解决办法了.     要解

两个系统的form验证 登录一个系统 另一个居然变成相同的用户了

问题描述 HttpCookieauthCookie=FormsAuthentication.GetAuthCookie(userName,false);//得到ticket凭据FormsAuthenticationTicketticket=FormsAuthentication.Decrypt(authCookie.Value);//根据之前的ticket凭据创建新ticket凭据,然后加入自定义信息FormsAuthenticationTicketnewTicket=newFormsAuthe

spring mvc-Springmvc中如何设置登录一个账号长时间不进行操作 就会自动跳出登录页面?

问题描述 Springmvc中如何设置登录一个账号长时间不进行操作 就会自动跳出登录页面? Springmvc中如何设置登录一个账号长时间不进行操作 就会自动跳出登录页面? 解决方案 方法有很多种. 我推荐你用filter来做, filter作为验证用户提交的请求(当user==null时跳转) 而当前用户的登录信息放进session中即可, 长时间不操作会自动清除的. 解决方案二: shiro.设置超时 解决方案三: 配置文件里配置session时效 解决方案四: 把session设置一下时效