Shiro框架配置与 IniRealm 使用详解
需积分: 31 114 浏览量
更新于2024-08-18
收藏 468KB PPT 举报
本文档介绍了如何使用Apache Shiro框架基于ini文件进行配置,以及Shiro的核心组件和工作流程。
Apache Shiro是一个强大的Java安全框架,主要用于处理认证、授权和会话管理。它提供了简单易用的API,使得开发者能够轻松地实现应用的安全控制。在基于ini文件的配置中,我们可以看到Shiro的配置主要包括了`SecurityManager`、`Realms`、`SessionManager`等关键组件的设置。
1. **配置部分解析**:
- `[main]` 部分是全局配置,定义了如登录URL、成功登录后的跳转URL、未授权角色和权限的错误页面,以及 Realm 的配置。
- `shiro.loginUrl` 指定用户未认证时重定向的URL。
- `authc.successUrl` 和 `roles.unauthorizedUrl`、`perms.unauthorizedUrl` 分别是认证成功后的跳转URL和权限不足时的错误页面。
- `inirealm` 和 `myrealm` 是两个不同的 Realm 类型,分别使用 IniRealm 和 自定义的 MongodbRealm,用来从不同的数据源获取用户信息。
- `adminDao` 配置了自定义 Realm 使用的数据访问对象。
- `sessionManager` 和 `securityManager` 配置了会话管理和安全管理器,其中 sessionManager 还添加了会话监听器。
- `[users]` 部分用于测试,直接定义了一些用户及其密码和权限。
2. **核心组件**:
- **Subject**: 表示当前操作的用户,可以理解为安全主体,是Shiro的对外接口,供应用程序调用。
- **SecurityManager**: 是整个Shiro的核心,管理所有组件,负责协调它们进行认证和授权等操作。
- **Realm**: Realm 是Shiro与应用安全数据之间的桥梁,每个Realm负责从特定的数据源获取用户和权限信息。
3. **其他主要组件**:
- **Authenticator**: 负责认证,验证用户的凭证是否正确。
- **Authorizer**: 授权组件,负责确定用户是否有权限执行某个操作。
- **SessionManager**: 管理用户的会话,包括创建、更新、删除会话等操作。
- **CacheManager**: 提供缓存支持,提高Shiro组件的性能。
4. **Shiro认证过程**:
- 用户尝试登录时,创建一个AuthenticationToken实例并传递给Subject的login()方法。
- Subject实例委托SecurityManager进行登录操作。
- SecurityManager通过Authenticator调用Realm进行认证,如果配置了多个Realm,将根据AuthenticationStrategy进行多Realm认证。
- Realm会查询其背后的数据源验证用户信息,返回认证结果。
- 认证成功后,SecurityManager会创建并返回一个代表已认证Subject的PrincipalCollection。
通过这样的配置,Shiro可以根据ini文件中的设置动态地进行用户管理和权限控制,为应用程序提供全面的安全保障。在实际开发中,开发者可以根据具体需求自定义Realm和过滤器链,以适应不同的认证和授权场景。
116 浏览量
2017-03-10 上传
116 浏览量
2021-04-30 上传
2021-03-30 上传
2021-04-11 上传
2022-09-21 上传
105 浏览量
123 浏览量