最近 Confluence 官方通报了一个严重漏洞 CVE-2022-26134,远程攻击者在未经身份验证的情况下,可构造OGNL表达式进行注入,实现在Confluence Server或Data Center上执行任意代码。
Confluence Server and Data Center >= 1.3.0
Confluence Server and Data Center < 7.4.17
Confluence Server and Data Center < 7.13.7
Confluence Server and Data Center < 7.14.3
Confluence Server and Data Center < 7.15.2
Confluence Server and Data Center < 7.16.4
Confluence Server and Data Center < 7.17.4
Confluence Server and Data Center < 7.18.1
使用docker-compose文件进行漏洞环境搭建
使用命令docker-compose up -d成功启动环境后,查看容器id等相关信息(5050为远程调式端口)
进入容器后将/opt/atlassian目录下的confluence源码使用docker cp命令复制到本地
使用IDEA将/confluence/WEB-INF下的atlassian-bundled-plugins、atlassian-bundled-plugins-setup、lib文件拉取为依赖文件
IDEA中配置远程调式
在容器中/opt/atlassian/confluence/bin目录下修改setenv.sh文件,加入远程调式配置
访问http://IP:8090, 进行相关配置(需要登陆confluence官网进行证书申请)
漏洞分析环境成功搭建。
成功命令执行
漏洞分析
以登陆请求为例,对confluence请求处理流程进行调试分析
首先访问/login.action,经过一系列Filter处理后,将进入Servlet 的分发器 ServletDispatcher
com.opensymphony.webwork.dispatcher.ServletDispatcher
在ServletDispatcher中,通过getNameSpace 、getActionName 、 getRequestMap 、 getSessionMap 、 getApplicationMap函数 ,分别去获取对应的值。(使用payload=/${4*4}/)
重点分析getNamespace函数,其对应的值为namespace
在com.opensymphony.webwork.dispatcher.ServletDispatcher#getNamespace中
通过调用com.atlassian.plugin.servlet.PluginHttpRequertWrapper#getServletPath函数,获取了请求servletPath的值
随后进入回到com.opensymphony.webwork.dispatcher.ServletDispatcher中进入getNamespaceFromServletPath函数
通过对字符串的截取 ,使得namespace 的取值为请求 servletPath 最后一个"/"之前的部分。
根据com.opensymphony.webwork.dispatcher.ServletDispatcher#serviceAction函数
到com.opensymphony.xwork.DefaultActionProxy#execute,实例化 DefaultActionProxy 对象,调用其 execute 函数
随后进入com.opensymphony.xwork.DefaultActionlnvocation#invoke函数,通过Next获取拦截器对象
继续跟进来到com.opensymphony.xwork.interceptor.Aroundlnterceptor#intercept,发现invoke函数通过调用intercept方法,形成迭代循环
通过不断调式,发现在满足一定条件之后,将不会继续调用invoke函数,而是将返回 notpermitted 并赋值给 resultCode,跳出循环。
随后进入com.opensymphony.xwork.ActionChainResult#execute函数
这里通过getNamespace获取namespace的值,前面我们已经分析出来:namespace的取值为请求servletPath最后一个"/"之前的部分
继续跟进,在com.opensymphony.xwork.ActionChainResult中,会调用translateVariables函数对OGNL表达式进行解析,表达式的值为namespace的取值
在com.opensymphony.xwork.util.TextParseUtil#translateVariables中
调用了com.opensymphony.xwork.util.OgnlValueStack#findValue函数对表达式进行解析
一系列操作之后,findValue返回的字符串为16
成功触发 OGNL 表达式注入
建议升级到Atlassian Confluence Server and Data Center至安全版本。
下载链接:
https://www.atlassian.com/software/confluence/download-archives
从 v7.15 系列开始,Confluence 在 OGNL 表达式解析时加入了沙箱限制,采取了黑名单、白名单等方式。
绕过的技巧:白名单(限制为静态方法调用)中,仍然有一些静态方法可绕过沙箱限制或者沙箱本身逻辑上也存在相关缺陷可实现方法调用。
https://www.little2pig.work/archives/cve-2022-26134
https://my.atlassian.com/products/index
https://attackerkb.com/topics/BH1D56ZEhs/cve-2022-26134/rapid7-analysis
https://cve.mitre.org/cgi-bin/cvename.cgi?name=2022-26134
https://www.tarlogic.com/blog/cve-2022-26134-zero-day-vulnerability-affecting-atlassian-confluence/