Hello Mr.J——shiro 简单地认识
2016-07-31 20:39
369 查看
当年由于项目紧张,没什么人能接手这部分内容,我就随便的接下了维护shiro和cas的任务,然后就一直在做这的维护,一直没有仔细的研究一下,做做总结。
这些日子,很多人也都来问我关于这方面的东西,我这里只能零零碎碎的说一些我知道的内容,没有做过过多的解释。
这几天没闲着,终于是理清楚了项目中shiro使用了哪些功能,可以简单了聊两句了。
Apache Shiro是一个强大易用的Java安全框架,提供了认证、授权、加密和会话管理功能,可为任何应用提供安全保障 - 从命令行应用、移动应用到大型网络及企业应用。
这张图相信大家都见过,上图的几个部分描述了shiro的几个功能和特性。
Authentication:身份认证/登录,验证用户是不是拥有相应的身份;
Authorization:授权,即权限验证,验证某个已认证的用户是否拥有某个权限;即判断用户是否能做事情,常见的如:验证某个用户是否拥有某个角色。或者细粒度的验证某个用户对某个资源是否具有某个权限;
Session Manager:会话管理,即用户登录后就是一次会话,在没有退出之前,它的所有信息都在会话中;会话可以是普通JavaSE环境的,也可以是如Web环境的;
Cryptography:加密,保护数据的安全性,如密码加密存储到数据库,而不是明文存储;
Web Support:Web支持,可以非常容易的集成到Web环境;
Caching:缓存,比如用户登录后,其用户信息、拥有的角色/权限不必每次去查,这样可以提高效率
Concurrency:shiro支持多线程应用的并发验证,即如在一个线程中开启另一个线程,能把权限自动传播过去;
Testing:提供测试支持;
Run As:允许一个用户假装为另一个用户(如果他们允许)的身份进行访问;
Remember Me:记住我,这个是非常常见的功能,即一次登录后,下次再来的话不用登录了。
从架构的角度看,Shiro大概流程是这样的一张图。
用户登陆之后,需要获取验证信息,这个验证信息shiro提供了一个对象Subject,我们可以从这个对象中获得我们想要的东西,包括用户信息,授权,Session信息等等。
而Subject中的内容,是由SecurityManager来管理,这个类是Shiro的大总管,他汇总了各种与安全有关的功能,我们使用的时候在Spring中配置一下就行了。
最后是执行验证的东西,Realms,Shiro从从Realm获取安全数据(如用户、角色、权限),就是说SecurityManager要验证用户身份,那么它需要从Realm获取相应的用户进行比较以确定用户身份是否合法;也需要从Realm得到用户相应的角色/权限进行验证用户是否能进行操作;
我们通过Subject来进行认证和授权,而Subject又委托给SecurityManager,SecurityManager注入Realm,从而让SecurityManager能得到合法的用户及其权限进行判断。
我们现在来放大SecurityManager,来看看这里面到底有什么。
Authenticator:认证器,负责主体认证的,这是一个扩展点,如果用户觉得 Shiro默认的不好,可以自定义实现;其需要认证策略 (Authentication Strategy ),即什么情况下算用户认证通过了
Authrizer:授权器,或者访问控制器,用来决定主体是否有权限进行相应的操作;即控制着用户能访问应用中的哪些功能。
Realm:数据源,用户的数据都是通过Realm来的,一般我们在Realm里面写自己的查询逻辑。
SessionManager:这个东西很强大,他能实现Session共享,Shiro通过将Session进行一次封装,封装成自己的Session类型来管理Session,以此来实现分布式回话。
SessionDAO:我觉得这个是属于SessionManager的一部分,他是专门来将Session进行持久化的。
差不多就这样了,还有一些其他的东西下次再继续。
这些日子,很多人也都来问我关于这方面的东西,我这里只能零零碎碎的说一些我知道的内容,没有做过过多的解释。
这几天没闲着,终于是理清楚了项目中shiro使用了哪些功能,可以简单了聊两句了。
Apache Shiro是一个强大易用的Java安全框架,提供了认证、授权、加密和会话管理功能,可为任何应用提供安全保障 - 从命令行应用、移动应用到大型网络及企业应用。
这张图相信大家都见过,上图的几个部分描述了shiro的几个功能和特性。
Authentication:身份认证/登录,验证用户是不是拥有相应的身份;
Authorization:授权,即权限验证,验证某个已认证的用户是否拥有某个权限;即判断用户是否能做事情,常见的如:验证某个用户是否拥有某个角色。或者细粒度的验证某个用户对某个资源是否具有某个权限;
Session Manager:会话管理,即用户登录后就是一次会话,在没有退出之前,它的所有信息都在会话中;会话可以是普通JavaSE环境的,也可以是如Web环境的;
Cryptography:加密,保护数据的安全性,如密码加密存储到数据库,而不是明文存储;
Web Support:Web支持,可以非常容易的集成到Web环境;
Caching:缓存,比如用户登录后,其用户信息、拥有的角色/权限不必每次去查,这样可以提高效率
Concurrency:shiro支持多线程应用的并发验证,即如在一个线程中开启另一个线程,能把权限自动传播过去;
Testing:提供测试支持;
Run As:允许一个用户假装为另一个用户(如果他们允许)的身份进行访问;
Remember Me:记住我,这个是非常常见的功能,即一次登录后,下次再来的话不用登录了。
从架构的角度看,Shiro大概流程是这样的一张图。
用户登陆之后,需要获取验证信息,这个验证信息shiro提供了一个对象Subject,我们可以从这个对象中获得我们想要的东西,包括用户信息,授权,Session信息等等。
而Subject中的内容,是由SecurityManager来管理,这个类是Shiro的大总管,他汇总了各种与安全有关的功能,我们使用的时候在Spring中配置一下就行了。
最后是执行验证的东西,Realms,Shiro从从Realm获取安全数据(如用户、角色、权限),就是说SecurityManager要验证用户身份,那么它需要从Realm获取相应的用户进行比较以确定用户身份是否合法;也需要从Realm得到用户相应的角色/权限进行验证用户是否能进行操作;
我们通过Subject来进行认证和授权,而Subject又委托给SecurityManager,SecurityManager注入Realm,从而让SecurityManager能得到合法的用户及其权限进行判断。
我们现在来放大SecurityManager,来看看这里面到底有什么。
Authenticator:认证器,负责主体认证的,这是一个扩展点,如果用户觉得 Shiro默认的不好,可以自定义实现;其需要认证策略 (Authentication Strategy ),即什么情况下算用户认证通过了
Authrizer:授权器,或者访问控制器,用来决定主体是否有权限进行相应的操作;即控制着用户能访问应用中的哪些功能。
Realm:数据源,用户的数据都是通过Realm来的,一般我们在Realm里面写自己的查询逻辑。
SessionManager:这个东西很强大,他能实现Session共享,Shiro通过将Session进行一次封装,封装成自己的Session类型来管理Session,以此来实现分布式回话。
SessionDAO:我觉得这个是属于SessionManager的一部分,他是专门来将Session进行持久化的。
差不多就这样了,还有一些其他的东西下次再继续。
相关文章推荐
- linux学习-常规命令使用5
- C++中的 using
- jQuery实现简单图片的轮播(自右向左播放)
- NodeMCU之旅(四):实现Web配置页面
- 聊聊高并发系统之限流特技-1
- 【JavaWeb框架学习】之Hibernate缓存机制、一级缓存和二级缓存介绍
- Sublime Text3设置SublimeREPL快捷键的方法(Python)
- mysql中set autocommit=0与start transaction区别
- Cookie工具类
- 华为OJ 合唱队
- POJ 3126 Prime Path (BFS)
- Silhouettes:聚类结果衡量指标
- Python基础——列表和元组
- 【字符串6】翻转单词顺序列
- 顺序建链表
- 关于投篮的几点建议
- POJ2217——Secretary(后缀数组应用)
- Oracle数据库错误记录
- TCP/IP详解学习笔记(6)-UDP协议
- MySQL无法远程连接解决方案