Cointime

扫码下载App
iOS & Android

HTTP提权漏洞CVE-2023-23410分析及PoC

2023年3月,HTTP协议被发现存在两个漏洞:本地提权漏洞和远程代码执行漏洞。本文将主要探讨本地提权漏洞CVE-2023-23410的发现和分析过程。

漏洞补丁分析

根据ZDI BLOG对这个月补丁的汇总,我们知道这个http提权漏洞是由研究人员提交给ZDI的一个整数溢出的漏洞。 对比更新前后的http代码,的确发现一个比较明显的整数溢出判断修补代码, 如下图所示:

初步分析该函数,发现这是一个循环保存ServiceName到内存的函数。并且ServiceName个数最多为0x40。然后补丁的作用是把单个ServiceName的长度限制为小于 0xfffc。

在之后的UlpAddServiceNameToContainer函数中有一个小疑惑:这里已经有一个另外的判断ServiceName长度小于0xFFFFFFE8。可以理解这里的判断是为了防止内存申请溢出,但这里的判断和本次补丁修补的判断0xfffc似乎差距太大。

分析代码路径,大方向上这里似乎有两种触发到漏洞补丁函数的途径。 一是通过对本地http服务的设置使用UlSetConfigGroupProperty或者UlSetServerSessionProperty都可以。 另外一种则是通过远程客户端的身份验证响应包,即UlCaptureHttpResponse获取UlExtractAndAppendAuthenticationResponseInfo中的ChannelBindConfig数据。

通常,如果http服务绑定一个对外的本地网络端口,则需要具备高系统权限。 在这里,我们尝试本地的http服务设置来触发漏洞函数补丁的代码路径。

构造PoC

参考微软对http API的一些说明,我们通过HttpSetUrlGroupProperty函数,将其第二个参数设置为HttpServerChannelBindProperty,然后逆向分析其中的一些数据结构以通过检查,我们可以自由设置UlCaptureChannelBindConfig函数中补丁限制的ServiceName长度。但这似乎并不能立即导致更严重的后果。

根据ChannelBindConfig这个关键字,我们注意到UlCopyChannelBindConfigToIrp函数。该函数会具体解析并复制结构体里面所有数据并拷贝到用户提供的缓冲区。并且在其内部函数UlpComputeChannelBindConfigSize中,存在其计算结果溢出的情况。这导致在之后的复制ChannelBindConfig中ServiceName的内容时触发崩溃。崩溃堆栈如下:

虽然此时已经有了一个明确的poc代码路径。但在分析补丁时的那个小疑惑似乎更大了。如果只考虑计算ServiceName时的溢出,为什么补丁修补的是小于一个WORD级别的长度0xfffc,而不是一个DWORD级别的长度即((0xffffffff-otherlenth)/0x40)?

我们参考关键字ServiceName,然后发现在http其他的地方的确总是以WORD的长度来设定ServiceName长度,如UlFindServiceNameInContainer,以及另外一个相关函数UlpIsServiceContainerEquivalent。可以发现http协议整体上都是设定ServiceName长度为WORD。

虽然此次我们构造的溢出是UlpComputeChannelBindConfigSize中产生的,但根本原因是因为UlCaptureChannelBindConfig中,对ServiceName的原始输入长度判断出现错误。

PoC链接:https://github.com/numencyber/Vulnerability_PoC.git

Exp构造问题

在目前的poc中,最终发生内存损坏的地方是HTTP映射到内核(MmMapLockedPagesSpecifyCache)的用户层缓冲区内存(如下图),这似乎限制了我们构造利用。

上面的V12是MDL的指针,目前通过本地http服务直接设置HttpQueryUrlGroupProperty的调用路径似乎并不能控制MDL->flags的标志包含MDL_MAPPED_TO_SYSTEM_VA(0x01)或MDL_SOURCE_IS_NONPAGED_POOL(0x04)。

除此之外,似乎只能再尝试找到http服务中其他存在处理ChannelBindConfig或者ServiceName内存长度的代码流程。

总结

回顾上面的流程,我们目前的方式都是从 http本地设置的过程中去触发溢出。 另外一种从UlCaptureHttpResponse中的UlExtractAndAppendAuthenticationResponseInfo(这里必须使用Kerberos身份验证方式)去调用UlCaptureChannelBindConfig的路径应该也是可行的。

不过之后要从客户端向服务端触发一个类似UlCopyChannelBindConfigToIrp的流程(触发计算servicename长度导致溢出)。这种调用方式可能需要进一步的分析。在目前分析到的UlpCompleteAuthInfo中的UlFindServiceNameInContainer或者UlpIsServiceContainerEquivalent似乎并不会直接引起内存损坏。

不过即使我们以客户端的方式从远程触发了某种溢出流程,但最终还有一个关键的问题,即最后被溢出损坏的内存最好是系统内核的内存如:分页内存或者非分页内存而不是锁定的用户层内存。 

参考链接

  • https://www.zerodayinitiative.com/blog/2023/3/14/the-march-2023-security-update-review
  • https://msrc.microsoft.com/update-guide/vulnerability/CVE-2023-23410
评论

所有评论

推荐阅读

  • BTC短时跌破60000美元

    行情显示,BTC短时跌破60000美元,现回升至61290.9美元,24小时跌幅3.5%,行情波动较大,请做好风险控制。

  • 易理华:美股如期回调,本轮下跌速度���超预期

    6月5日消息,Liquid Capital(前 LD Capital)创始人易理华表示,「如同我们预期的一致,美股开始回调,降息预期有变化。交易永远是最难的事情,对了十次错一次就会出问题,永远保持谨慎和控制风险,这一轮反弹后的下跌速度,远超过预期。但是也伴随着更大的机会,过去熊市才是挣钱机会,牛市都是亏钱操作。」

  • SpaceX的首次IPO所吸引的申购数量超过了可提供的股票数量

    6月5日,据媒体消息,SpaceX的首次公开募股(IPO)所吸引的申购数量超过了可提供的股票数量。

  • 美联储哈马克:目前维持利率稳定是合理的

    6月5日,美联储哈马克:可能很快就会到适合���整利率的时候。鉴于不确定性,目前维持利率稳定是合理的。

  • 机构:美国劳动力市场强劲 但消费者可能担心实际工资出现负增长

    6月5日,NorthwesternMutual财富管理公司首席投资官BrentSchutte表示,美国劳动力市场已经脱离2025年那种疲软且小范围增长的状态,恢复增长态势,且范围有所扩大。2025年非周期性医疗保健和美国经济中的社会援助领域贡献了全部的就业增长。2025年,扩散指数(在2025年12个月中有9个月低于50)在过去5个月中已回升至50以上,5月份达到54.4。对消费者而言,好消息是劳动力市场强劲,就业稳定。但对未来支出的担忧在于,在平均时薪同比上涨3.4%,通胀率达3.8%的情况下,实际工资出现负增长。美联储可能倾向于观望,但其关注点很可能会转向货币政策的通胀方面。

  • 美、布两油日内跌超2%

    6月5���讯,WTI原油日内下跌2.3%,现报92.18美元/桶。布伦特原油日内跌超2.2%,现报92.28美元/桶。

  • ETH跌破1600美元

    行情显示,ETH跌破1600美元,现报1594.99美元,24小时跌幅达到10.31%,行情波动较大,请做好风险控制。

  • BTC跌破60500美元

    行情显示,BTC跌破60500美元,现报60473.11美元,24小时跌幅达到5.52%,行情波动较大,请做好风险控制。

  • 现货白银失守70美元/盎司 现货黄金日内跌超100美元

    6月5日讯,现货白银失守70美元/盎司,为4月7日以来首次,日内跌幅达5.4%。现货黄金日内跌超100美元,现报4375.35美元/盎司,跌幅2.24%。

  • 美股光通信概念集体下挫,迈威尔科技大跌超8%

    6月5日,美股光通信概念股集体下挫,其中,迈威尔科技、诺基亚跌超8%,Ciena、Coherent跌超7%,康宁跌超6%,Lumentum跌超4%。