47、WEB攻防——通用漏洞&Java反序列化&EXP生成&数据提取&组件安全

文章目录

序列化和反序列化的概念:

  • 序列化:把java对象转换成字节流的过程;
  • 反序列化:把字节流恢复为java对象的过程。

对象的序列化主要有两种用途:

  1. 把对象的字节流永久的保存在硬盘上,通常存放在一个文件中(持久化对象);
  2. 在网络上传送对象的字节流(网络传输对象)。

序列化数据:

  • 功能特性
    反序列化操作一般应用在导入模板文件、网络通信、数据传输、日志格式化存储或DB存储等业务场景,因此审计中重点关注这些功能板块。
  • 数据特性
    一般数据以rO0AB开头,基本上可以确定这串就是JAVA反序列化base64加密的数据;如果aced(16进制)开头,那么它就是一段java序列化的16进制数据。
  • 序列化可能出现
    http参数、cookie、session、存储方式可能是base64(rO0),压缩后的base64(H4s),MLL等;
    Serverts http、Sockets、Session管理器,包含的协议包括:JMX、RMI、JMS、JND1等

发现

黑盒分析:数据库出现地------观察数据特性

白盒分析:组件安全&函数搜索&功能模块

序列化函数API:

  • JAVA:serializableExtemailzablefastjsonjacksongsonObjectInputStream.readObjectObjectInputStream.readUnshared等;
  • PHP:serialize()unserialize()
  • Python:pickle

生成java反序列化payload工具-ysoserial

使用ysoserial时,若要根据某个外部包生成payload,可以将该包复制到ysoserial目录下,确保paylaod的生成更加可靠。
ysoserial最终生成的payload是aced(16进制)的字节流,若需要编码应该进一步进行编码。

swagger接口:swagger-ui.html

JAVA反序列化解密工具:SerializationDumper

java特定组件:shirojboos

网鼎杯朱雀组2020 Think java

网鼎杯朱雀组2020 Think java

查看源代码发现swagger-ui api接口,url地址后面加上./swagger-ui.htm,结果如下图:

相关推荐
guozhetao4 分钟前
【ST表、倍增】P7167 [eJOI 2020] Fountain (Day1)
java·c++·python·算法·leetcode·深度优先·图论
技术思考者5 分钟前
基础很薄弱如何规划考研
java·经验分享·考研
●VON28 分钟前
重生之我在暑假学习微服务第二天《MybatisPlus-下篇》
java·学习·微服务·架构·mybatis-plus
老华带你飞28 分钟前
口腔助手|口腔挂号预约小程序|基于微信小程序的口腔门诊预约系统的设计与实现(源码+数据库+文档)
java·数据库·微信小程序·小程序·论文·毕设·口腔小程序
枫叶丹430 分钟前
【Qt开发】信号与槽(二)-> 信号和槽的使用
开发语言·qt
hqxstudying38 分钟前
J2EE模式---服务层模式
java·数据库·后端·spring·oracle·java-ee
GM_82844 分钟前
【最新最完整】SpringAI-1.0.0开发MCP Server,搭建MCP Client 实战笔记(进阶+详细+完整代码)
java·后端·ai编程·springai·mcp
都叫我大帅哥1 小时前
Java DelayQueue:时间管理大师的终极武器
java
秋千码途1 小时前
小架构step系列27:Hibernate提供的validator
java·spring·架构·hibernate
都叫我大帅哥1 小时前
TOGAF迁移规划阶段全解密:从菜鸟到达人的通关秘籍
java