JAVA攻防-Shiro专题&断点调试&有key利用链&URL&CC&CB&原生反序列化&加密逻辑

知识点:

Java攻防-Shiro反序列化

Java安全框架,能够用于身份验证、授权、加密和会话管理。

历史漏洞:https://avd.aliyun.com/search?q=Shiro

漏洞触发:CookieRememberMeManager

黑盒特征:数据包cookie有没有rememberme

漏洞原理:利用到原生类的readObject反序列化操作导致漏洞(相比多了对数据的aes加密和base64编码),所以利用要考虑这两点。

Shiro反序列化链知识点:

1、Shiro用途和验证逻辑

2、Shiro反序列化怎么造成

3、Shiro反序列化漏洞利用

Shiro反序列化链分析

当获取用户请求时,大致的关键处理过程如下:

· 获取CookierememberMe的值

· 对rememberMe进行Base64解码

· 使用AES进行解密

· 对解密的值进行反序列化

由于AES加密的Key是硬编码的默认Key,因此攻击者可通过使用默认的Key对恶意构造的序列化数据进行加密,当CookieRememberMeManager对恶意的rememberMe进行以上过程处理时,最终会对恶意数据进行反序列化,从而导致反序列化漏洞。

问题:为什么不能用fastjson里面的jdbc那个链?
fastjson链找有setxxxgetxxx方法里面触发rce
shiro链找有readObjecttoString方法里面触发rce

漏洞环境搭建

shiro官网:https://shiro.apache.org/














演示案例-Java攻防-Shiro反序列化-Shiro 550利用链分析

1、获取AES加密属性

成功登录:项目源码全局搜索rememberMeSuccessfulLogin关键字并下断点(动态调试)











2、获取key值和偏移量和base64编码




3、整体登录流程

bash 复制代码
加密的方式:AES/CBC/PKCS5Padding
key:[-112, -15, -2, 108, -116, 100, -28, 61, -99, 121, -104, -120, -59, -58, -102, 104] //比特流数据
iv:[6, -28, 13, 52, -37, -71, 7, -11, 112, 30, -61, 7, -19, 87, -55, -99] //比特流数据(这里的IV是随机性的,而不是固定值,iv随机性的话加密的结果每次都会变)

KEY值:kPH+bIxk5D2deZiIxcaaaA==

项目源码搜索DEFAULT_CIPHER_KEY_BYTES = 关键字可找到KEY值Base64.decode("kPH+bIxk5D2deZiIxcaaaA==");



4、手动将Payload进行加密(AES+BASE64)

一、URLDNS链

要攻击的话就要把urldns.txt的序列化内容进行AES加密并base64编码。






二、借助CC&CB链






5、项目直接生成可用POC(无需手动加密编码)

借助java-chains项目生成Poc(推荐用这个项目生成POC)

项目地址:https://github.com/vulhub/java-chains


相关推荐
野犬寒鸦3 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
wenzhangli73 小时前
ooderA2UI BridgeCode 深度解析:从设计原理到 Trae Solo Skill 实践
java·开发语言·人工智能·开源
HalvmånEver3 小时前
Linux:线程互斥
java·linux·运维
rainbow68893 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法
灵感菇_3 小时前
Java 锁机制全面解析
java·开发语言
indexsunny3 小时前
互联网大厂Java面试实战:Spring Boot微服务在电商场景中的应用与挑战
java·spring boot·redis·微服务·kafka·spring security·电商
娇娇乔木4 小时前
模块十一--接口/抽象方法/多态--尚硅谷Javase笔记总结
java·开发语言
saber_andlibert4 小时前
TCMalloc底层实现
java·前端·网络
wangjialelele4 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先
m0_481147334 小时前
拦截器跟过滤器的区别?拦截器需要注册吗?过滤器需要注册吗?
java