您所在的位置:首页>技术相关技术相关

Apache Tomcat AJP协议文件读取与包含漏洞以及修复方案

【返回上一页】  发布时间:2020-02-26  阅读:2299

漏洞介绍:2020年2月20日,阿里云应急响应中心监测到CNVD披露 Apache Tomcat 服务器AJP协议存在文件读取与包含高危漏洞。


Apache Tomcat文件包含漏洞(CNVD-2020-10487,对应CVE-2020-1938)。攻击者利用该漏洞,可在未授权的情况下远程读取特定目录下的任意文件。目前,漏洞细节尚未公开,厂商已发布新版本完成漏洞修复。


漏洞影响的产品版本: Tomcat 6 Tomcat 7 Tomcat 8 Tomcat 9


修复方案:升级到厂商最新版本


操作步骤:修复前首先要做的是备份,现在基本的云厂商都可以快照备份。


1.   如未使用Tomcat AJP协议:


如未使用 Tomcat AJP 协议,可以直接将 Tomcat 升级到 9.0.31、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.31、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" />


参考链接:https://www.cnvd.org.cn/webinfo/show/5415