Jeesite开发平台限制用户多点登录

Jeesite开发平台限制用户多点登录

	/**
	 * 授权查询回调函数, 进行鉴权但缓存中无用户的授权信息时调用
	 */
	@Override
	protected AuthorizationInfo doGetAuthorizationInfo(PrincipalCollection principals) {
		Principal principal = (Principal) getAvailablePrincipal(principals);
		// 获取当前已登录的用户
		if (!Global.TRUE.equals(Global.getConfig("user.multiAccountLogin"))) {
			Collection<Session> sessions = getSystemService().getSessionDao().getActiveSessions(true, principal,
					UserUtils.getSession());
			if (sessions.size() > 0) {
				if (UserUtils.getSubject().isAuthenticated()) {
					
					//限制用户只能在一处登录start
					for (Session session : sessions) {
						Object obj = session.getAttribute(DefaultSubjectContext.PRINCIPALS_SESSION_KEY);
						SimplePrincipalCollection coll = (SimplePrincipalCollection) obj;
						if (coll == null) {
							continue;
						}
						Principal user = (Principal) coll.getPrimaryPrincipal();
						String username = user.getLoginName();
						// 当第二次登录时,给出提示,禁止重复登录
						if (principal.loginName.equals(username)) {
							UserUtils.getSubject().logout();
							throw new AuthenticationException("msg:该用户已在其他设备登录,禁止重复登录!!!!");
						}
					}
					//限制用户只能在一处登录end
					
				}
			}
		}
		User user = getSystemService().getUserByLoginName(principal.getLoginName());
		if (user != null) {
			SimpleAuthorizationInfo info = new SimpleAuthorizationInfo();
			List<Menu> list = UserUtils.getMenuList();
			for (Menu menu : list) {
				if (StringUtils.isNotBlank(menu.getPermission())) {
					// 添加基于Permission的权限信息
					for (String permission : StringUtils.split(menu.getPermission(), ",")) {
						info.addStringPermission(permission);
					}
				}
			}
			// 添加用户权限
			info.addStringPermission("user");
			// 添加用户角色信息
			for (Role role : user.getRoleList()) {
				info.addRole(role.getEnname());
			}
			// 更新登录IP和时间
			getSystemService().updateUserLoginInfo(user);
			// 记录登录日志
			LogUtils.saveLog(Servlets.getRequest(), "系统登录");
			return info;
		} else {
			return null;
		}
	}

 

以上,请参考!


参考链接

  1. jeesite限制用户只能在一处登录
  2. 框架中如何限制用户只能在一处登录
  3. 如何限制同一客户端登录的用户数量以及禁止同一用户同时在不同客户端登录?
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Jeesite 是一个开源的 Java 开发平台,它可以帮助开发者快速搭建基于 Java 的企业级应用程序。它提供了一套完整的解决方案,包括应用框架、数据库框架、搜索引擎、开发工具等,可以帮助开发者快速搭建和维护企业级应用。 ### 回答2: Jeesite是一个基于Java语言的开发平台,它提供了一整套的开发工具、框架和模块,旨在帮助开发人员快速构建和部署企业级Web应用程序。 首先,Jeesite具备强大的代码生成工具。开发人员只需通过配置实体属性和数据库连接,即可自动生成相关的CRUD(增删改查)代码,大大提高了开发效率。同时,Jeesite还支持在线表单设计器和报表设计器,使得开发人员可以在图形化界面上设计和生成各种复杂的表单和报表。 其次,Jeesite拥有完善的权限管理系统。它支持角色、用户和权限的管理,可以实现对不同用户的访问权限和操作权限的精细控制。开发人员可以通过简单的配置实现权限控制,同时还提供了安全的登录认证机制,保证系统的安全性。 此外,Jeesite还具备丰富的模块和组件。它集成了常用的功能模块,如机构管理、用户管理、菜单管理、字典管理等,开发人员可以直接使用这些模块来快速搭建系统的基础功能。同时,Jeesite还支持插件化开发开发人员可以根据需求灵活地添加、扩展和定制功能模块。 最后,Jeesite采用了先进的技术架构和设计理念。它基于Spring、SpringMVC和MyBatis等优秀的开源框架,采用模块化的设计思路,使得系统具有良好的可扩展性和可维护性。同时,Jeesite还支持多数据源和分布式部署,可以满足大规模系统的需求。 综上所述,Jeesite是一个功能丰富、易于使用和高效开发的企业级Web应用程序开发平台,它的出现让开发人员能够更加专注于业务逻辑的实现,提升开发效率和质量。 ### 回答3: Jeesite是一个基于Java语言开发的开源企业级快速开发平台。它提供了一套完整的开发框架和工具,帮助开发人员快速搭建企业级应用系统。 首先,Jeesite拥有丰富的功能模块,包括权限管理、用户管理、组织机构管理、角色管理、菜单管理等。这些模块可以方便地进行配置和管理,满足了企业级应用系统的常见需求。 其次,Jeesite采用了MVC的设计模式,将应用程序按照业务逻辑进行分层,分别是Model层、View层和Controller层。这样可以实现代码的复用和解耦,提高开发效率。 此外,Jeesite还集成了很多流行的开源组件和框架,例如Spring、Hibernate、Mybatis等。这些组件和框架可以帮助开发人员更加高效地开发应用,提供了良好的开发体验。 同时,Jeesite还提供了一套灵活的插件机制,可以根据具体项目需求自定义扩展。开发人员可以根据业务需求,自行开发插件并集成到Jeesite平台中,实现个性化定制。 总之,Jeesite是一个功能丰富、扩展灵活的开发平台,适用于各种规模的企业级应用系统开发。通过使用Jeesite开发人员可以快速搭建稳定高效的应用系统,提高开发效率,降低开发成本。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值