安全(权限)框架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…...
前端面试:【性能优化】页面加载性能、渲染性能、资源优化
嗨,亲爱的前端开发者!在今天的Web世界中,用户期望页面加载速度快、交互流畅。因此,前端性能优化成为了至关重要的任务。本文将探讨三个关键方面的性能优化:页面加载性能、渲染性能以及资源优化,以帮助你构建…...
从按下电源键到进入系统,CPU在干什么?
本专栏更新速度较慢,简单讲讲计算机的那些事,简单讲讲那些特别散乱杂的知识,欢迎各位朋友订阅专栏啊 感谢一路相伴的朋友们 浅淡操作系统系列第2篇 目录 通电 保护模式和实模式 内存管理单元MMU 逻辑地址?物理地址࿱…...
TypeScript初体验
1.安装编译TS工具包 npm i -g typescript 2. 查看版本号 tsc -v 3.创建ts文件 说明:创建一个index.ts文件 4.TS编译为JS tsc index.ts 5.执行JS代码 node index.js 6.简化TS的步骤 6.1安装 npm i -g ts-node 6.2执行 ts-node index.ts...
基于 Alpine 环境源码构建 alibaba-tengine(阿里巴巴)的 Docker 镜像
About Alpine(简介) Alpine Linux 是一款极其轻量级的 Linux 发行版,基于 busybox,多被当做 Docker 镜像的底包(基础镜像),在使用容器时或多或少都会接触到此系统,本篇文章我们以该镜…...
政府网站定期巡检:构建高效、安全与透明的数字政务
在数字时代,政府网站已不仅仅是一个信息发布窗口,更是政府与公众互动的桥梁、政务服务的主要渠道以及数字化治理的重要平台。因此,确保政府网站的高效运行、信息安全与透明公开就显得尤为重要。在此背景下,定期的网站巡检与巡查成…...
C++信息学奥赛1138:将字符串中的小写字母转换成大写字母
#include<bits/stdc.h> using namespace std; int main() {string arr;// 输入一行字符串getline(cin, arr);for(int i0;i<arr.length();i){if(arr[i]>97 and arr[i]<122){char aarr[i]-32; // 将小写字母转换为大写字母cout<<a; // 输出转换后的字符}els…...
leetcode1475. 商品折扣后的最终价格 【单调栈】
简单题 第一次错误做法 class Solution { public:vector<int> finalPrices(vector<int>& prices) {int n prices.size();stack<int> st;unordered_map<int, int> mp;int i 0;while(i ! prices.size()) {int t prices[i];if (st.empty() || t …...
macOS M1使用TensorFlow GPU加速
本人是在pycharm运行代码,安装了tensorflow版本2.13.0 先运行代码查看有没有使用GPU加速: import tensorflow as tf# Press the green button in the gutter to run the script. if __name__ __main__:physical_devices tf.config.list_physical_dev…...
GNU-gcc编译选项-1
include目录 -I ,比如: -I. -I ./Platform/include -I ./Platform/include/prototypes -I ./tpm/include -I ./tpm/include/prototypes -I ./Simulator/include -I ./Simulator/include/prototypes 编译选项 在GCC编译器中,-D是一个编译选项&…...
【DEVOPS】Jenkins使用问题 - 控制台输出乱码
0. 目录 1. 问题描述2. 解决方案3. 最终效果4. 总结 1. 问题描述 部门内部对于Jenkins的使用采取的是Master Slave Work Node的方式,即作为Master节点的Jenkins只负责任务调度,具体的操作由对应的Slave Work Node去执行。 最近团队成员反馈一个问题&a…...
wordpress markdownk/网站制作建设公司
1什么是 dive?用于探索 Docker 镜像、每一层中的内容以及发现缩小 Docker/OCI 镜像大小的方法的工具。2安装 divego get github.com/wagoodman/div3dive 特性按层分解 Docker 镜像可视化展示每一层变化分析镜像空间使用百分比快速构建分析镜像支持多种镜像源和容器引擎4入门使…...
网络水果有哪些网站可以做/百度推广登录后台登录入口
apscheduler使用uWSGI的mule模块部署的时候报错, 因为系统时区和代码运行时区不一样导致。 解决办法:在初始化的时候指定上海的时区 scheduler BlockingScheduler(timezone"Asia/Shanghai") 转载于:https://www.cnblogs.com/duanzq/p/1127061…...
和政网站建设/深圳最新通告今天
1.版本1:发送请求 # -*- coding:utf-8 -*-import struct from socket import *#0. 获取要下载的文件名字: downloadFileName raw_input("请输入要下载的文件名:") #1.创建socket udpSocket socket(AF_INET, SOCK_DGRAM)requestFileData struct.pack…...
wordpress无法创建目录安装失败/软件外包
将软间隔支持向量机看做正则化模型 上一小节中我们介绍了软间隔支持向量机,该模型允许有错分类数据的存在,从而使模型对数据有更好的适应性,有效避免过拟合的问题。 现在我们回顾一下松弛变量ξn,我们用ξn来记录违反分类边界的…...
鞍山网站建设鞍山/网站推广优化排名教程
进程 是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程,是操作系统进行资源分配和调度的一个独立单位,是应用程序运行的载体。进程是一种抽象的概念,从来没有统一的标准定义。进程一般由程序,数据集合和进程控制…...
网站模板制作教程视频/百度代发排名
master进程为主进程,该进程会创建Manager进程和Reactor线程等工作进/线程Reactor线程实际运行epoll实例,用于接受客户端的链接和发来的请求 Manager进程是管理进程,该进程是为了创建管理所有的worker进程和TaskWorker进程,而TaskWorker则是manager直接生成的子进程。worker进程…...