關於Apache Tomcat遠程讀取特定目錄下的任意文件漏洞

最近更新時間 2020-02-22 16:06:52

2020年1月6日,國家信息安全漏洞共享平臺(CNVD)收錄了由北京長亭科技有限公司發現並報送的Apache Tomcat文件包含漏洞(CNVD-2020-10487,對應CVE-2020-1938)。攻擊者利用該漏洞,可在未授權的情況下遠程讀取特定目錄下的任意文件。目前,漏洞細節尚未公開,廠商已發佈新版本完成漏洞修復。

一、漏洞情況分析

Tomcat是Apache軟件基金會Jakarta 項目中的一個核心項目,作為目前比較流行的Web應用服務器,深受Java愛好者的喜愛,並得到了部分軟件開發商的認可。Tomcat服務器是一個免費的開放源代碼的Web應用服務器,被普遍使用在輕量級Web應用服務的構架中。

2020年1月6日,國家信息安全漏洞共享平臺(CNVD)收錄了由北京長亭科技有限公司發現並報送的Apache Tomcat文件包含漏洞。Tomcat AJP協議由於存在實現缺陷導致相關參數可控,攻擊者利用該漏洞可通過構造特定參數,讀取服務器webapp下的任意文件。若服務器端同時存在文件上傳功能,攻擊者可進一步實現遠程代碼的執行。

CNVD對該漏洞的綜合評級為“高危”。

二、漏洞影響範圍

漏洞影響的產品版本包括:

  • Tomcat 6
  • Tomcat 7
  • Tomcat 8
  • Tomcat 9

CNVD平臺對Apache Tomcat AJP協議在我國境內的分佈情況進行統計,結果顯示我國境內的IP數量約為55.5萬,通過技術檢測發現我國境內共有43197臺服務器受此漏洞影響,影響比例約為7.8%。

三、漏洞處置建議

目前,Apache官方已發佈9.0.31、8.5.51及7.0.100版本對此漏洞進行修復,CNVD建議用戶儘快升級新版本或採取臨時緩解措施:

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" />
rss_feed