博客
关于我
shiro笔记二:shiro基础概念和架构
阅读量:793 次
发布时间:2019-03-25

本文共 1063 字,大约阅读时间需要 3 分钟。

Shiro笔记二:基础概念与架构分析

Shiro核心知识架构与四大模块

identities认证

身份认证是用户登录系统的基本功能,Shiro通过安全管理器(SecurityManager)来处理认证流程。大多数情况下,用户登录会触发认证过程,以确保用户身份的真实性。

授权(Authorization)

授权是为用户赋予访问资源或角色权限的过程。在Shiro中,授权由安全管理器负责,确保用户在访问系统资源时具备相应的权限。

会话管理(Session Management)

会话管理确保用户在访问系统时保持连接状态。这通常涉及Web会话的创建、更新以及终止,用于维持用户的活动状态。

加密(Cryptography)

数据安全是应用的重要需求。Shiro提供了强大的 加密和 解密功能,简化了常见加密技术的使用,使得在开发中更加便捷。

其他小组件

Shiro不仅仅提供认证和授权功能,还包含丰富的支持组件:

  • Web支持组件:帮助开发者快速集成功能。
  • 缓存组件:用于提高系统性能。
  • 并发组件:处理高并发场景。
  • 测试组件:自带单元测试功能。
  • 模拟访问(Run AS):用于测试不同用户的访问行为。
  • 记住我功能:实现用户的快速登录。

用户访问整合Shiro系统的权限控制流程

在实际系统中,用户的访问流程通常包括以下几个关键步骤:

主体(Subject)

主体可以是用户、第三方服务或自动化任务。他们通常通过访问系统资源或服务门户,触发权限控制流程。

安全管理器(SecurityManager)

安全管理器是整个流程的核心,负责协调认证、授权和会话管理等关键任务。

认证器(Authenticator)

认证器负责处理用户的身份验证,确认用户身份是否合法。

数据域(Realm)

数据域是连接外部数据系统的桥梁,例如数据库或LDAP。它提供必要的认证和授权信息。

授权器(Authorizer)

授权器检查用户的权限,决定是否允许访问特定资源或执行操作。

加密工具(Cryptography)

加密工具处理数据的加密和解密,确保数据传输过程中的安全性。

缓存管理器(CacheManager)

缓存管理器可以存储常用数据以提高性能,提升用户体验。

Shiro系统架构图

下图展示了Shiro主要模块的结构图:

[注:此处应放置架构图,但因图片链接需处理,建议直接删除或替换为占位词。]


通过以上分析可以清晰地理解Shiro的核心架构和相关组件,以及用户访问控制流程。理解这些内容对于熟悉Shiro框架的配置与使用是非常重要的。

转载地址:http://jwuyk.baihongyu.com/

你可能感兴趣的文章
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>