Apache Tomcat AJP协议漏洞如何导致文件读取与包含?

Apache Tomcat AJP协议文件读取与包含漏洞

Apache Tomcat作为广泛使用的开源Java Web应用服务器,其AJP(Apache JServ Protocol)协议在反向代理场景中扮演着重要角色,AJP协议的设计缺陷曾导致严重的文件读取与包含漏洞(CVE-2020-1938、CVE-2020-35489等),攻击者可利用该漏洞读取服务器敏感文件甚至执行任意代码,本文将从漏洞原理、影响范围、复现方式及防御措施等方面展开分析。

Apache Tomcat AJP协议漏洞如何导致文件读取与包含?

AJP协议与漏洞背景

AJP协议是Tomcat与Web服务器(如Apache HTTP Server、Nginx)之间的高性能通信协议,基于二进制格式设计,支持长连接和请求复用,常用于负载均衡和静态资源分离场景,协议通过ajp13实现,允许Web服务器将HTTP请求转发至Tomcat处理。

漏洞的核心问题在于AJP协议对请求参数的校验不足,当Tomcat开启了AJP连接器(默认端口8009)且未正确配置secret属性时,攻击者可通过构造特殊的AJP请求,绕过Tomcat的访问控制,读取Web应用目录外的敏感文件(如WEB-INF配置文件、系统配置等),或在特定条件下实现远程代码执行。

漏洞原理与利用方式

文件读取漏洞(CVE-2020-1938)

  • 漏洞触发条件

    • Tomcat版本:9.0.x < 9.0.31,8.5.x < 8.5.51,7.0.x < 7.0.100。
    • AJP连接器已启用且未配置secret
    • 支持AJP协议的反向代理(如mod_jk、mod_proxy_ajp)将流量转发至Tomcat。
  • 利用原理
    攻击者通过AJP协议发送包含javax.servlet.include.request_uri等恶意头部的请求,Tomcat在处理时会将请求参数与内部路径拼接,导致目录穿越,构造请求:

    GET /xxx HTTP/1.1  
    Host: target  
    Accept: */*  
    X-Forwarded-For: 127.0.0.1  
    Referer: http://xxx  
    Proxy-Connection: Keep-Alive  
    Content-Type: application/x-www-form-urlencoded  
    X-Forwarded-Host: 127.0.0.1  
    X-Forwarded-Server: 127.0.0.1  
    Content-Length: 0  

    结合工具(如ysoserial)或直接请求/index.jsp,可读取WEB-INF/web.xml/etc/passwd等文件。

    Apache Tomcat AJP协议漏洞如何导致文件读取与包含?

远程代码执行漏洞(CVE-2020-35489)

  • 触发条件

    • Tomcat版本:9.0.x < 9.0.36,8.5.x < 8.5.63,7.0.x < 7.0.93。
    • 存在可上传恶意文件(如JSP)的Web应用。
  • 利用链
    攻击者先通过文件读取漏洞获取SessionContext信息,再结合包含漏洞(如include指令)加载恶意JSP文件,最终导致代码执行。

    <%@ include file="file:///etc/passwd" %>  

    若服务器存在文件上传功能,可上传Webshell并通过AJP协议触发执行。

漏洞影响范围

影响范围 具体场景
敏感信息泄露 读取WEB-INF/web.xml(数据库配置)、/etc/passwd(系统用户)、.ssh目录等。
服务器权限获取 结合漏洞读取配置文件,进一步获取系统权限或横向移动。
业务中断 攻击者可篡改页面或植入恶意代码,导致服务不可用或用户数据泄露。

漏洞复现步骤(以文件读取为例)

  1. 环境准备

    • 部署受影响版本的Tomcat(如9.0.30),启用AJP连接器(server.xml中配置<Connector port="8009" protocol="AJP/1.3" />)。
    • 使用mod_proxy_ajp将Apache请求转发至Tomcat。
  2. 工具利用
    使用ysoserialCeye平台构造Payload,通过curl发送AJP请求:

    Apache Tomcat AJP协议漏洞如何导致文件读取与包含?

    curl -H "X-Forwarded-Host: 127.0.0.1" -H "X-Forwarded-For: 127.0.0.1" "http://target:8009/"  

    观察响应中是否包含/etc/passwd内容。

  3. 验证结果
    若返回文件内容,则漏洞存在;若返回404或权限错误,则可能未受影响。

防御与修复措施

官方补丁升级

  • Tomcat版本升级
    • 0.x升级至9.0.31+,8.5.x升级至8.5.51+,7.0.x升级至7.0.100+。
    • 下载地址:Apache Tomcat官网

配置加固

  • 禁用AJP连接器:若无需AJP协议,在server.xml中注释或删除AJP Connector配置。
    <!-- <Connector port="8009" protocol="AJP/1.3" /> -->  
  • 启用secret属性:若必须使用AJP,配置secret参数(需与Web服务器一致):
    <Connector port="8009" protocol="AJP/1.3" secret="yourSecretKey" />  

网络与访问控制

  • 防火墙限制:仅允许可信IP访问AJP端口(8009)。
  • 反向代理配置:在Web服务器层(如Nginx)禁用不必要的AJP转发,或使用mod_security过滤恶意请求。

安全审计与监控

  • 定期扫描:使用NucleiAWVS等工具检测AJP端口是否存在漏洞。
  • 日志分析:监控Tomcat访问日志,关注异常路径(如/WEB-INF//etc/)。

Apache Tomcat AJP协议漏洞的本质是协议层面对路径遍历和文件包含的校验缺失,随着Tomcat官方版本的迭代,高危漏洞已逐步修复,但未升级或配置不当的系统仍面临风险,建议用户及时更新版本,严格限制AJP协议的访问范围,并结合网络层防护措施,构建多层次安全体系,对于企业级应用,还需定期开展渗透测试和代码审计,从源头避免类似漏洞的引入。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/16465.html

(0)
上一篇 2025年10月20日 03:26
下一篇 2025年10月20日 03:31

相关推荐

  • 商洛安服务器价格为何如此吸引人?性价比揭秘与选购建议!

    商洛安服务器价格解析与选购指南商洛安服务器概述商洛安服务器作为一款高性能、稳定的云计算产品,凭借其卓越的性能和优质的服务,在市场上获得了广泛的认可,本文将为您详细介绍商洛安服务器的价格、配置以及选购指南,商洛安服务器价格商洛安服务器价格区间商洛安服务器价格区间较为广泛,根据配置的不同,价格从几千元到上万元不等……

    2025年11月3日
    0810
  • 服务器计算容量多少钱?不同配置价格差异大吗?

    服务器计算容量的价格构成与影响因素服务器计算容量的价格并非一个固定数值,而是由硬件配置、服务模式、品牌溢价、地域差异及附加服务等多重因素共同决定的,企业在选择服务器时,需根据自身业务需求,在性能、成本与扩展性之间找到平衡点,本文将从核心价格要素、主流服务模式及选购建议三个维度,详细解析服务器计算容量的定价逻辑……

    2025年12月7日
    01880
  • 日本CN2 GIA VPS怎么样?丽萨主机回程优化VPS避坑指南

    日本CN2 GIA线路因其卓越的低延迟和高稳定性,一直是建站及外贸用户的首选,但市场上关于“回程优化”的宣传鱼龙混杂,丽萨主机作为业内知名品牌,其日本CN2 GIA VPS的实际表现与宣传是否存在偏差,是用户最为关心的问题,经过深度实测与长期追踪,可以明确得出结论:丽萨主机在CN2 GIA线路上的确具备核心竞争……

    2026年3月13日
    0713
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • 负载均衡配置中,如何有效优化访问日志记录?

    在当今互联网高速发展的时代,负载均衡已经成为保障网站稳定性和提高访问效率的重要手段,负载均衡配置的访问日志对于监控和分析网站性能具有重要意义,本文将详细介绍负载均衡配置访问日志的相关知识,包括日志的配置、分析方法和实际应用案例,负载均衡配置访问日志概述负载均衡配置访问日志是指记录负载均衡器接收到的所有请求的详细……

    2026年2月2日
    0720

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注