常见中间件漏洞:Tomcat篇

Tomcat介绍

tomcat是⼀个开源而且免费的jsp服务器,默认端口 : 8080,属于轻量级应用服务器。它可以实现
JavaWeb程序的装载,是配置JSP(Java Server Page)和JAVA系统必备的⼀款环境。

一、CVE-2017-12615

漏洞描述

当 Tomcat运行在Windows操作系统时,且启⽤了HTTP PUT请求方法(例如,将 readonly初始化参数 由默认值设置为false),攻击者将有可能可通过精心构造的攻击请求数据包向服务器上传包含任意代码 的 JSP 文件,JSP文件中的恶意代码将能被服务器执行。导致服务器上的数据泄露或获取服务器权限。

漏洞原理

当在Tomcat的conf(配置目录下)/web.xml配置文件中添加readonly设置为false时,将导致该漏洞产 生,(需要允许put请求) , 攻击者可以利⽤PUT方法通过精心构造的数据包向存在漏洞的服务器里面上 传 jsp⼀句话文件,从而造成远程命令执行,getshell等。

影响范围

Apache Tomcat 7.0.0 - 7.0.79

Apache Tomcat 8.5.19

环境搭建

cd vulhub-master/tomcat/CVE-2017-12615

docker-compose up -d

漏洞复现

打开网站

抓包

修改,上传的内容为哥斯拉生成的木马

访问1.jsp

复制链接即可


漏洞修复
设置readonly 为 true

二、后台弱口令部署war包

漏洞原理

在tomcat8环境下默认进⼊后台的密码为 tomcat/tomcat ,未修改造成未授权即可进⼊后台,或者管 理员把密码设置成弱口令。

影响版本

全版本

环境搭建

8cd vulhub-master/tomcat/tomcat8

docker-compose up -d

漏洞复现

默认密码:tomcat/tomcat
打开网址

输入上面的账号密码登录

制作war包,如图所示先压缩再改后缀

上传war包

访问网站

链接即可

漏洞修复

1.设置强口令

2.删除manger文件

三、CVE-2020-1938

漏洞原理

11由于Tomcat AJP协议设计上的缺陷,攻击者通过Tomcat AJP Connector 可以读取或包含Tomcat上所 有 Webapp目录下的任意文件,例如: 可以读取webapp配置文件或源码文件。 此外如果目标应用有文件上传的功能情况下,配合为⽂件包含漏洞利⽤GetShell。

影响版本

Apache Tomcat 6

Tomcat 7系列 <7.0.100 Tomcat 8系列 < 8.5.51 Tomcat 9 系列 <9.0.31

环境搭建

cd vulhub-master/tomcat/CVE-2020-1938

docker-compose up -d

漏洞复现

打开网站

在kali运行代码

复制代码
python2 '/home/kali2023/Desktop/CVE-2020-1938-Tomact-file_include-file_read-master/Tomcat-ROOT路径下文件包含(CVE-2020-1938).py'  -p 8009 -f /WEB-INF/web.xml 8.130.17.222
Getting resource at ajp13://8.130.17.222:8009/asdf.jsp

读取到文件

漏洞修复

1.更新到最新版本

2.关闭AJP服务,修改Tomcat配置⽂件Service.xml,注释掉。

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

3.配置ajp配置中的secretRequired跟secret属性来限制认证。

相关推荐
不爱编程的小九九15 分钟前
小九源码-springboot097-java付费自习室管理系统
java·开发语言·spring boot
独自破碎E36 分钟前
LeetCode 381: O(1) 时间插入、删除和获取随机元素 - 允许重复
java·算法·leetcode
程语有云39 分钟前
生产事故-Caffeine缓存误用之临下班的救赎
java·缓存·caffeine·阻塞·log·生产事故
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 81: 最大子数组和
java·数据结构·算法·leetcode·决策树·职场和发展·深度优先
CodeCraft Studio1 小时前
国产化Word处理控件Spire.Doc教程:用Java实现TXT文本与Word互转的完整教程
java·c#·word·spire.doc·word文档转换·txt转word·word转txt
徐子童1 小时前
数据结构---优先级队列(堆)
java·数据结构·面试题·优先级队列··topk问题
滑水滑成滑头1 小时前
**标题:发散创新:智能交通系统的深度探究与实现**摘要:本文将详细
java·人工智能·python
siriuuus2 小时前
Maven 核心概念及生命周期
java·maven
闭着眼睛学算法2 小时前
【双机位A卷】华为OD笔试之【哈希表】双机位A-跳房子I【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·c++·python·算法·华为od·散列表
孔明兴汉2 小时前
Cursor MCP 第一章-第一节-MCP协议简介.md
java·ai