博客
关于我
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 - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>