安全(权限)框架Shiro概述及原理
1.1 Shiro
是什么
Apache Shiro
是一个功能强大且易于使用的Java
安全(权限)框架。Shiro
可以完成:认证、授权、加密、会话管理、与Web
集成、缓存 等。借助Shiro
您可以快速轻松地保护任何应用程序——从最小的移动应用程序到最大的Web
和企业应用程序。
官网:https://shiro.apache.org/
1.2 为什么要用Shiro
自 2003 年以来,框架格局发生了相当大的变化,因此今天仍然有很多系统在使用Shiro
。这与Shiro
的特性密不可分。
-
易于使用:使用
Shiro
构建系统安全框架非常简单。就算第一次接触也可以快速掌握。 -
全面:
Shiro
包含系统安全框架需要的功能,满足安全需求的“一站式服务”。 -
灵活:
Shiro
可以在任何应用程序环境中工作。虽然它可以在Web
、EJB
和IoC
环境中工作,但不需要依赖它们。Shiro
也没有强制要求任何规范,甚至没有很多依赖项。 -
强力支持
Web
:Shiro
具有出色的Web
应用程序支持,可以基于应用程序URL
和Web
协议(例如REST
)创建灵活的安全策略,同时还提供一组JSP
库来控制页面输出。 -
兼容性强:
Shiro
的设计模式使其易于与其他框架和应用程序集成。Shiro
与Spring
、Grails
、Wicket
、Tapestry
、Mule
、Apache Camel
、Vaadin
等框架无缝集成。 -
社区支持:
Shiro
是Apache
软件基金会的一个开源项目,有完备的社区支持,文档支持。如果需要,像Katasoft
这样的商业公司也会提供专业的支持和服务。
1.3 Shiro
与Spring Security
的对比
Spring Security
基于Spring
开发,项目若使用Spring
作为基础,配合Spring Security
做权限更加方便,而Shiro
需要和Spring
进行整合开发;Spring Security
功能比Shiro
更加丰富些,例如安全维护方面;Spring Security
社区资源相对比Shiro
更加丰富;Shiro
的配置和使用比较简单,Spring Security
上手复杂些;Shiro
依赖性低,不需要任何框架和容器,可以独立运行,Spring Security
依赖Spring
容器;shiro
不仅仅可以使用在web
中,它可以工作在任何应用环境中。在集群会话时Shiro
最重要的一个好处或许就是它的会话是独立于容器的。
1.4 基本功能
1.4.1 基本功能点
如下图所示:
1.4.2 功能简介
(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
:记住我,这个是非常常见的功能,即一次登录后,下次再来的话不用登录了。
1.5 原理
1.5.1 Shiro
架构(Shiro
外部来看)
从外部来看Shiro
,即从应用程序角度的来观察如何使用Shiro
完成工作
Shiro
架构
(1)Subject
:应用代码直接交互的对象是Subject
,也就是说Shiro
的对外API
核心就是Subject
。Subject
代表了当前“用户”, 这个用户不一定 是一个具体的人,与当前应用交互的任何东西都是Subject
,如网络爬虫, 机器人等;与Subject
的所有交互都会委托给SecurityManager
;Subject
其实是一个门面,SecurityManager
才是实际的执行者;
(2)SecurityManager
:安全管理器;即所有与安全有关的操作都会与SecurityManager
交互;且其管理着所有Subject
;可以看出它是Shiro
的核心,它负责与Shiro
的其他组件进行交互,它相当于SpringMVC
中 DispatcherServlet
的角色
(3)Realm
:Shiro
从Realm
获取安全数据(如用户、角色、权限),就是说SecurityManager
要验证用户身份,那么它需要从Realm
获取相应的用户 进行比较以确定用户身份是否合法;也需要从Realm
得到用户相应的角色/ 权限进行验证用户是否能进行操作;可以把Realm
看成DataSource
。
1.5.2 Shiro
架构(Shiro
内部来看)
Shiro
架构
(1)Subject
:任何可以与应用交互的“用户”;
(2)SecurityManager
:相当于SpringMVC
中的DispatcherServlet
;是Shiro
的心脏; 所有具体的交互都通过SecurityManager
进行控制;它管理着所有Subject
、且负责进 行认证、授权、会话及缓存的管理。
(3)Authenticator
:负责Subject
认证,是一个扩展点,可以自定义实现;可以使用认证策略(Authentication Strategy
),即什么情况下算用户认证通过了;
(4)Authorizer
:授权器、即访问控制器,用来决定主体是否有权限进行相应的操作;即控 制着用户能访问应用中的哪些功能;
(5)Realm
:可以有 1 个或多个Realm
,可以认为是安全实体数据源,即用于获取安全实体的;可以是JDBC
实现,也可以是内存实现等等;由用户提供;所以一般在应用中都需要实现自己的Realm
;
(6)SessionManager
:管理Session
生命周期的组件;而Shiro
并不仅仅可以用在Web
环境,也可以用在如普通的JavaSE
环境;
(7)CacheManager
:缓存控制器,来管理如用户、角色、权限等的缓存的;因为这些数据基本上很少改变,放到缓存中后可以提高访问的性能;
仅仅可以用在Web
环境,也可以用在如普通的JavaSE
环境;
(7)CacheManager
:缓存控制器,来管理如用户、角色、权限等的缓存的;因为这些数据基本上很少改变,放到缓存中后可以提高访问的性能;
(8)Cryptography
:密码模块,Shiro
提高了一些常见的加密组件用于如密码加密/解密。
相关文章:

安全(权限)框架Shiro概述及原理
1.1 Shiro是什么 Apache Shiro是一个功能强大且易于使用的Java安全(权限)框架。Shiro可以完成:认证、授权、加密、会话管理、与Web集成、缓存 等。借助Shiro您可以快速轻松地保护任何应用程序——从最小的移动应用程序到最大的Web和企业应用…...

java: 无法访问org.springframework.boot.SpringApplication 错误的类文件
项目场景: 提示:这里简述项目相关背景: 错误1: java: 无法访问org.springframework.boot.SpringApplication 错误的类文件: /D:/Software/env-java/apache-maven-3.6.1/repository/org/springframework/boot/spring-boot/3.1.2/sp…...

改进YOLO系列:7.添加CA注意力机制
添加CA注意力机制 1. CA注意力机制论文2. CA注意力机制原理3. CA注意力机制的配置3.1common.py配置3.2yolo.py配置3.3yaml文件配置1. CA注意力机制论文 论文题目:Coordinate Attention for Efficient Mobile Network Design 论文链接:Coordinate Attention for Effi…...
Linux笔记--Ubuntu设置sftp服务
目录 1--修改配置文件 2--注销代码 3--更改代码 4--重启服务 1--修改配置文件 vim /etc/ssh/sshd_config 2--注销代码 ① 注销: Subsystem sftp /usr/libexec/openssh/sftp-server ② 更改为: Subsystem sftp internal-sftp 3--更改代码 Per…...

火山引擎边缘云,助你沉浸式回忆童年
发现了吗?在抖音、西瓜视频上能观看4K修复的经典港片了!得益于抖音、中国电影资料馆、火山引擎共同发起的“经典香港电影修复计划”,我们童年时期看过的《大话西游之大圣娶亲》《武状元苏乞儿》等22部港片以更清晰、流畅、颜色饱满的状态回归…...

Axios跨域请求处理
问题背景: vue 项目用 axios 进行请求的时候,总是报“Access to XMLHttpRequest at ‘http://localhost:8889/api/login’ from origin ‘http://localhost:8080……’”的错误 实际上就是前后端分离的情况下,发生了跨域的问题 跨域定义&…...

Docker(二) Docker容器
在docker中的容器都是由镜像所创建的,一个镜像可以创建多个容器。 一、调试Docker 启动Docker systemctl start docker 查看Docker中有哪些镜像 docker images 下载镜像 docker pull hello-world 运行镜像 docker run hello-world 出现 Hello from Docker! 这…...

【业务功能篇81】微服务SpringCloud-ElasticSearch-Kibanan-docke安装-入门实战
ElasticSearch 一、ElasticSearch概述 1.ElasticSearch介绍 ES 是一个开源的高扩展的分布式全文搜索引擎,是整个Elastic Stack技术栈的核心。它可以近乎实时的存储,检索数据;本身扩展性很好,可以扩展到上百台服务器,…...

【UniApp开发小程序】私聊功能uniapp界面实现 (买家、卖家 沟通商品信息)【后端基于若依管理系统开发】
文章目录 效果显示WebSocket连接使用全局变量WebSocket连接细节 最近和自己聊天的用户信息界面效果界面代码最近的聊天内容太长日期时间显示未读消息数量显示 私聊界面界面展示代码实现英文长串不换行问题聊天区域自动滑动到底部键盘呼出,聊天区域收缩,聊…...

【BASH】回顾与知识点梳理(三十六)
【BASH】回顾与知识点梳理 三十六 三十六. 认识与分析登录档36.1 什么是登录档CentOS 7 登录档简易说明登录档的重要性Linux 常见的登录档档名登录档所需相关服务 (daemon) 与程序CentOS 7.x 使用 systemd 提供的 journalctl 日志管理 登录档内容的一般格式 36.2 rsyslog.servi…...

十三、pikachu之暴力破解
文章目录 1、暴力破解概述2、基于表单的暴力破解3、验证码的绕过3.1 验证码的认证流程3.2 验证码绕过(on client)3.3 验证码绕过(on server)3.4 token防爆破? 1、暴力破解概述 “暴力破解”是一攻击具手段,…...

用手势操控现实:OpenCV 音量控制与 AI 换脸技术解析
基于opencv的手势控制音量和ai换脸 HandTrackingModule.py import cv2 import mediapipe as mp import timeclass handDetector():def __init__(self, mode False, maxHands 2, model_complexity 1, detectionCon 0.5, trackCon 0.5):self.mode modeself.maxHands max…...

【leetcode 力扣刷题】移除链表元素 多种解法
移除链表元素的多种解法 203. 移除链表元素解法①:头节点单独判断解法②:虚拟头节点解法③:递归 203. 移除链表元素 题目链接:203.移除链表元素 题目内容: 理解题意:就是单纯的删除链表中所有值等于给定的…...

leetcode503. 下一个更大元素 II 单调栈
思路: 与之前 739、1475 单调栈的问题如出一辙,唯一不同的地方就是对于遍历完之后。栈中元素的处理,之前的栈中元素因无法找到符合条件的值,直接加入vector中。而这里需要再重头遍历一下数组,找是否有符合条件的&…...
Oracle中列的维护
由于商业环境中,数据是不断变化的,客户的需求也是不断变化的,所以当一个表用了一段时间后,其结构就有可能需要变化。 而在Oracle中,提供了alter table这种方式来改变列。 从Oracle9.2版本之后: 如果需要变…...
后端项目开发:分页功能的实现(Mybatis+pagehelper)
分页查询是项目中的常用功能,此处我们基于Mybatis对分页查询进行处理。 引入分页依赖 <!-- pagehelper --> <dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId>…...
SpringBoot集成Drools
一:简介 规则引擎全称为业务规则管理系统(Business Rule Management System)简称BRMS,主要思想是将应用程序中的业务决策部分分离开来,并使用预定义的语义模块编写业务决策(业务规则),由用户或开发者在需要时进行配置、管理。 其实就是将计算逻辑写在脚本中,通过Jav…...
React创建组件的三种方式及其区别是什么?
在React中,创建组件的三种主要方式是函数式组件、类组件和使用React Hooks的函数式组件。以下是对每种方式的详细解释以及它们之间的区别: 1、函数式组件: 函数式组件是使用纯粹的JavaScript函数来定义的。它接收一个props对象作为参数&…...

W6100-EVB-PICO进行UDP组播数据回环测试(九)
前言 上一章我们用我们的开发板作为UDP客户端连接服务器进行数据回环测试,那么本章我们进行UDP组播数据回环测试。 什么是UDP组播? 组播是主机间一对多的通讯模式, 组播是一种允许一个或多个组播源发送同一报文到多个接收者的技术。组播源将…...

Qt 阴影边框
阴影边框很常见,诸如360以及其他很多软件都有类似效果,了解CSS3的同学们应该都知道box-shadow,它就是来设定阴影效果的,那么Qt呢?看过一些资料,说是QSS是基于CSS2的,既然如此,box-sh…...

IDEA运行Tomcat出现乱码问题解决汇总
最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…...

华为云AI开发平台ModelArts
华为云ModelArts:重塑AI开发流程的“智能引擎”与“创新加速器”! 在人工智能浪潮席卷全球的2025年,企业拥抱AI的意愿空前高涨,但技术门槛高、流程复杂、资源投入巨大的现实,却让许多创新构想止步于实验室。数据科学家…...
【Linux】shell脚本忽略错误继续执行
在 shell 脚本中,可以使用 set -e 命令来设置脚本在遇到错误时退出执行。如果你希望脚本忽略错误并继续执行,可以在脚本开头添加 set e 命令来取消该设置。 举例1 #!/bin/bash# 取消 set -e 的设置 set e# 执行命令,并忽略错误 rm somefile…...
逻辑回归:给不确定性划界的分类大师
想象你是一名医生。面对患者的检查报告(肿瘤大小、血液指标),你需要做出一个**决定性判断**:恶性还是良性?这种“非黑即白”的抉择,正是**逻辑回归(Logistic Regression)** 的战场&a…...
DockerHub与私有镜像仓库在容器化中的应用与管理
哈喽,大家好,我是左手python! Docker Hub的应用与管理 Docker Hub的基本概念与使用方法 Docker Hub是Docker官方提供的一个公共镜像仓库,用户可以在其中找到各种操作系统、软件和应用的镜像。开发者可以通过Docker Hub轻松获取所…...

8k长序列建模,蛋白质语言模型Prot42仅利用目标蛋白序列即可生成高亲和力结合剂
蛋白质结合剂(如抗体、抑制肽)在疾病诊断、成像分析及靶向药物递送等关键场景中发挥着不可替代的作用。传统上,高特异性蛋白质结合剂的开发高度依赖噬菌体展示、定向进化等实验技术,但这类方法普遍面临资源消耗巨大、研发周期冗长…...

渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止
<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet: https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...
生成 Git SSH 证书
🔑 1. 生成 SSH 密钥对 在终端(Windows 使用 Git Bash,Mac/Linux 使用 Terminal)执行命令: ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 参数说明: -t rsa&#x…...

跨链模式:多链互操作架构与性能扩展方案
跨链模式:多链互操作架构与性能扩展方案 ——构建下一代区块链互联网的技术基石 一、跨链架构的核心范式演进 1. 分层协议栈:模块化解耦设计 现代跨链系统采用分层协议栈实现灵活扩展(H2Cross架构): 适配层…...

04-初识css
一、css样式引入 1.1.内部样式 <div style"width: 100px;"></div>1.2.外部样式 1.2.1.外部样式1 <style>.aa {width: 100px;} </style> <div class"aa"></div>1.2.2.外部样式2 <!-- rel内表面引入的是style样…...