Tomcat AJP 文件包含漏洞(CVE-2020-1938)漏洞复现

漏洞简介

该漏洞是因为Tomcat AJP协议存在缺陷而致使,攻击者利用该漏洞可经过构造特定参数,读取服务器webapp下的任意文件。若目标服务器同时存在文件上传功能,攻击者可进一步实现远程代码执行python

影响范围

Apache Tomcat 6git

Apache Tomcat 7 < 7.0.100github

Apache Tomcat 8 < 8.5.51web

Apache Tomcat 9 < 9.0.31tomcat

漏洞验证

对目标主机进行端口扫描安全

能够看到8009端口是打开的,运行AJP服务服务器

进一步使用poc验证,读取web.xmlapp

地址 https://github.com/0nise/CVE-2020-1938webapp

命令 python tomcat.py read_file --webapp=ROOT/ /WEB-INF/classes/application.yml 127.0.0.1ui

 

 修复方案

1)如未使用Tomcat AJP协议:

如未使用 Tomcat AJP 协议,能够直接将 Tomcat 升级到 9.0.3一、8.5.51或 7.0.100 版本进行漏洞修复。

如没法当即进行版本更新、或者是更老版本的用户,建议直接关闭AJPConnector,或将其监听地址改成仅监听本机localhost。

具体操做:

(1)编辑 <CATALINA_BASE>/conf/server.xml,找到以下行(<CATALINA_BASE> 为 Tomcat 的工做目录):

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

(2)将此行注释掉(也可删掉该行):

<!--<Connectorport="8009" protocol="AJP/1.3"redirectPort="8443" />-->

(3)保存后需从新启动,规则方可生效。

2)若是使用了Tomcat AJP协议:

建议将Tomcat当即升级到9.0.3一、8.5.51或7.0.100版本进行修复,同时为AJP Connector配置secret来设置AJP协议的认证凭证。例如(注意必须将YOUR_TOMCAT_AJP_SECRET更改成一个安全性高、没法被轻易猜解的值):

<Connector port="8009"protocol="AJP/1.3" redirectPort="8443"address="YOUR_TOMCAT_IP_ADDRESS" secret="YOUR_TOMCAT_AJP_SECRET"/>

如没法当即进行版本更新、或者是更老版本的用户,建议为AJPConnector配置requiredSecret来设置AJP协议认证凭证。例如(注意必须将YOUR_TOMCAT_AJP_SECRET更改成一个安全性高、没法被轻易猜解的值):

<Connector port="8009"protocol="AJP/1.3" redirectPort="8443"address="YOUR_TOMCAT_IP_ADDRESS"requiredSecret="YOUR_TOMCAT_AJP_SECRET" />

相关文章
相关标签/搜索