1, 什么是shiro

Apache Shiro 是Java 的一个安全框架。Shiro 可以非常容易的开发出足够好的应用,其不仅可以用在JavaSE 环境,也可以用在JavaEE 环境。Shiro 可以帮助我们完成:认证、授权、加密、会话管理、与Web 集成、缓存等。

2,为什么要学shiro

    1,既然shiro将安全认证相关的功能抽取出来组成一个框架,使用shiro就可以非常快速的完成认证、授权等功能的开发,降低系统成本。2,shiro使用广泛,shiro可以运行在web应用,非web应用,集群分布式应用中越来越多的用户开始使用shiro。

java领域中spring security(原名Acegi)也是一个开源的权限管理框架,但是spring security依赖spring运行,而shiro就相对独立,最主要是因为shiro使用简单、灵活,所以现在越来越多的用户选择shiro。

3,基本功能


1,Authentication
身份认证/登录,验证用户是不是拥有相应的身份;
2, Authorization
授权,即权限验证,验证某个已认证的用户是否拥有某个权限;即判断用
户是否能做事情,常见的如:验证某个用户是否拥有某个角色。或者细粒度的验证某个用
户对某个资源是否具有某个权限;
3, Session Manager
会话管理,即用户登录后就是一次会话,在没有退出之前,它的所有信
息都在会话中;会话可以是普通JavaSE环境的,也可以是如Web环境的;
4,Cryptography
加密,保护数据的安全性,如密码加密存储到数据库,而不是明文存储;
5,Web Support
Web 支持,可以非常容易的集成到Web 环境;
6,Caching
缓存,比如用户登录后,其用户信息、拥有的角色/权限不必每次去查,这样可以提高效率;
7,Concurrency
shiro 支持多线程应用的并发验证,即如在一个线程中开启另一个线程,能 把权限自动传播过去;
8,Testing
提供测试支持;
9,Run As
允许一个用户假装为另一个用户(如果他们允许)的身份进行访问;
10,Remember Me
记住我,这个是非常常见的功能,即一次登录后,下次再来的话不用登录
了。
注意:Shiro 不会去维护用户、维护权限;这些需要我们自己去设计/提供;然后通过 相应的接口注入给Shiro即可。

4,架构说明


1,Subject
Subject即主体,外部应用与subject进行交互,subject记录了当前操作用户,将用户的概念理解为当前操作的主体,可能是一个通过浏览器请求的用户,也可能是一个运行的程序。 Subject在shiro中是一个接口,接口中定义了很多认证授相关的方法,外部程序通过subject进行认证授,而subject是通过SecurityManager安全管理器进行认证授权
2,SecurityManager
SecurityManager即安全管理器,对全部的subject进行安全管理,它是shiro的核心,负责对所有的subject进行安全管理。通过SecurityManager可以完成subject的认证、授权等,实质上SecurityManager是通过Authenticator进行认证,通过Authorizer进行授权,通过SessionManager进行会话管理等。
SecurityManager是一个接口,继承了Authenticator, Authorizer, SessionManager这三个接口。
3,Authenticator
Authenticator即认证器,对用户身份进行认证,Authenticator是一个接口,shiro提供ModularRealmAuthenticator实现类,通过ModularRealmAuthenticator基本上可以满足大多数需求,也可以自定义认证器。
4,Authorizer
Authorizer即授权器,用户通过认证器认证通过,在访问功能时需要通过授权器判断用户是否有此功能的操作权限。
5,realm
Realm即领域,相当于datasource数据源,securityManager进行安全认证需要通过Realm获取用户权限数据,比如:如果用户身份数据在数据库那么realm就需要从数据库获取用户身份信息。
注意:不要把realm理解成只是从数据源取数据,在realm中还有认证授权校验的相关的代码。
6,sessionManager
sessionManager即会话管理,shiro框架定义了一套会话管理,它不依赖web容器的session,所以shiro可以使用在非web应用上,也可以将分布式应用的会话集中在一点管理,此特性可使它实现单点登录。
7,SessionDAO
SessionDAO即会话dao,是对session会话操作的一套接口,比如要将session存储到数据库,可以通过jdbc将会话存储到数据库。
8,CacheManager
CacheManager即缓存管理,将用户权限数据存储在缓存,这样可以提高性能。
9,Cryptography
Cryptography即密码管理,shiro提供了一套加密/解密的组件,方便开发。比如提供常用的散列、加/解密等功能。

5,下载Shiro和maven的依赖

http://shiro.apache.org/download.html

格言:不驰于空想,不骛于虚声

Shiro框架的简介相关推荐

  1. Apache Shiro 框架简介

    一.什么是Shiro Apache Shiro是一个强大易用的Java安全框架,提供了认证.授权.加密和会话管理等功能: 认证 - 用户身份识别,常被称为用户"登录": 授权 ...

  2. Spring集成Shiro框架实战

    文章目录 一:什么是Shiro框架 二:Shiro框架简介 1.Shiro基础功能点介绍 2.Shiro的工作原理 3.Shiro的内部工作结构 4.Shiro的身份认证流程 三:Spring集成Sh ...

  3. SpringBoot2.0 整合 Shiro 框架,实现用户权限管理

    GitHub源码地址:知了一笑 https://github.com/cicadasmile/middle-ware-parent 一.Shiro简介 1.基础概念 Apache Shiro是一个强大 ...

  4. shiro框架基础--shiro框架概念及原理

    一 shiro的简介 shiro是apache的一个开源框架,是一个权限管理的框架,实现 用户认证.用户授权. 二 shiro的架构图 authenticator:认证器,主体进行认证最终通过auth ...

  5. shiro框架的基本理解

    1.简介 shiro是一个安全框架,可以进行认证.授权.密码加密.会话管理 从外部来解析shiro框架: **Subject:**主体,代表了当前"用户",这个用户不一定是一个具体 ...

  6. Shiro框架使用及配置之权限管理系统(1)

    Shiro框架使用及配置 提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 Shiro框架使用及配置 前言 一.权限管理系统 1.简介: 2.Shrio框架 二.相关配置文件 ...

  7. Shiro框架在项目中的应用

    1.Shiro 框架简介 Shiro 概述 Shiro 是Apache公司推出一个权限管理框架,其内部封装了项目中认证,授权,加密,会话等逻辑操作,通过Shiro框架可以简化我们项目权限控制逻辑的代码 ...

  8. shiro框架---解决权限限制问题

    shiro简介 Apache Shiro是一个强大而灵活的开源安全框架,它能够干净利落地处理身份认证,授权,企业会话管理和加密(核心功能). 以下是你可以用 Apache Shiro所做的事情: 1. ...

  9. Shiro框架和JWT

    目录 shiro简介 1.认证 2.授权 3.shiro靠什么做认证与授权 JWT简介 创建JWTUtil工具类 令牌封装成对象 AuthenticationToken类 AuthorizingRea ...

最新文章

  1. Blender纹理基础学习视频教程 CGCookie – Fundamentals of Texturing in Blender
  2. 计算机网络(谢希仁)-第一章:概述
  3. C++学习基础三——迭代器基础
  4. JSON格式以及基本用法
  5. shell:多个文件按行合并
  6. Android camera(4)---Android Camera开发之基础知识篇
  7. rtx服务器端消息监控插件,RTX2006消息监控插件
  8. 基于BC95之AT命令的学习
  9. w3school离线文档分享。
  10. 微信公众号 菜单 { “errcode“: 47001, “errmsg“: “data format error rid: 61b36b ...“}
  11. linux usb模拟网卡,开发板作为USB设备模拟网卡(linux usb 网卡)--gadgetrndis|cdc
  12. xp系统安装金蝶k3服务器配置,xp安装金蝶k3安全设置.doc
  13. python 手机号码归属 ip地址查询
  14. ES6 对象数组查找某一个对象
  15. 点集凸包算法python实现(二)
  16. BGP Confederation(BGP联邦)
  17. python_变量特性、作用域、函数
  18. xpath常见错误:Opening and ending tag mismatch: meta line 4 的处理方法【Python爬虫】
  19. 个人简历特长及自我评价怎么写?
  20. 基于51单片机的水族箱温度水质监测智能宠物金鱼喂食器补氧换水proteus仿真原理图

热门文章

  1. 个人手机游戏开发者之死
  2. 南大计算机系为啥不升格为学院,11所大学正式更名,4所学院升格为大学,这3所民办大学极具迷惑性...
  3. source insight取消文件备份功能backup
  4. 基于CF(协同过滤)推荐算法
  5. 第四十八章 SQL函数 DAYOFMONTH
  6. linux查看录音驱动程序,linux驱动由浅入深系列:ALSA框架详解 音频子系统之二
  7. ART与Dalvik哪个好 ART模式和Dalvik模式区别对比
  8. 【Python】小甲鱼课后习题第17、18、19讲--函数(上)
  9. (数据结构)二叉排序树的插入、删除
  10. 成都百知教育告诉你申请shopee店铺需要用什么营业执照!