问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
某IP广播系统代码审计
漏洞分析
对某IP广播系统的一次代码审计
0x00 审计前的准备 =========== ```php 以下相关漏洞已全部提交cnvd ``` data:image/s3,"s3://crabby-images/49474/49474622f985d2102e4ab75e56ef9d28268ff3ba" alt="01.png" 熟悉目录整体架构 php目录为 代码的功能实现 主要审计php目录 0x01 文件上传getshell ================= `uplaod/mt_parser.php` 漏洞关键位置代码 data:image/s3,"s3://crabby-images/2660b/2660b045254452a25ad9802e49679c1897e504b9" alt="02.png" 无任何过滤直接构造poc上传即可 ```html <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title></title> </head> <body> <form action="http://127.0.0.1/upload/my_parser.php" enctype="multipart/form-data" method="post"> <input class="input_file" type="file" name="upload"/> <input class="button" type="submit" name="submit" value="upload"/> </form> </body> </html> ``` 漏洞证明截图 data:image/s3,"s3://crabby-images/5c8e3/5c8e36cbb199c7f91279681509081af0d48dfe43" alt="03.png" 0x02 查看文件 ========= 开始审计php目录下的文件 发现均包含了`conversion.php` data:image/s3,"s3://crabby-images/72f99/72f994577d3ff577bb4f16df10bf952c39fdfef3" alt="04.png" 进行查看 具体实现的功能 共写了八个方法,一个个看一下 1、`function arrayRecursive(&$array, $function, $apply_to_keys_also = false)` data:image/s3,"s3://crabby-images/c0137/c013755556084e9fbe1ac3029f2d0156b3f43189" alt="05.png" 大体实现了 第一个参数传`array` 第二个参数传`function` 分别对`array`的`value`进行`function`操作。 如果`apply_to_keys_also`为`true`还可以对传入的`array`进行改变`key`值 2、`function JSON($array, $want_url_encode = true)` data:image/s3,"s3://crabby-images/a6db9/a6db9e4ab06859825b9ed4011fa7f5922f435365" alt="06.png" 大体实现了 对传入的数组进行`json_encode` 然后`urldecode`操作(这里可能实现了中文字符的传入) 3、`function UdpSendJson($array, $msgType)` data:image/s3,"s3://crabby-images/94be1/94be1bf7a144c81c972ef800b4b474393ab0e8d2" alt="07.png" 大体实现了 一个传送JSON数据的功能 4、`function UdpSend($msg)` data:image/s3,"s3://crabby-images/9208a/9208accb5c244903b31675bf1ca9121499011e33" alt="08.png" 大体实现了 对`8888`端口下的`AppWebService`的命令操作 具体干什么可能要看硬件设备了。 5、`function UdpSendAndRecvJson($array, $msgType)` data:image/s3,"s3://crabby-images/257a7/257a733845c870fc1a687f3f89e894908b340722" alt="09.png" 大体实现了 接收和发送JSON数据 6、`function UdpSendAndRecv($msg)` data:image/s3,"s3://crabby-images/70902/709022495ab75fe09c7886adf0e5e20831b11ee4" alt="10.png" 大体实现了 发送和接收数据,对本地的`8888`端口发送一个`POST`请求 这里和`function UdpSend()`实现了一样的操作,只不过多加了一个Linux下的操作 7、`function phplog($data)` data:image/s3,"s3://crabby-images/89ca4/89ca4a3007456dad1085fe889f49806c172dfda2" alt="11.png" 大体实现了 写日志的功能 8、`function get_real_ip()` data:image/s3,"s3://crabby-images/7965c/7965cd0c95c5a4ebdcceae5176664805f1e8f911" alt="12.png" 大体实现了 通过`Client_ip`头获取了`ip` 接下来看php目录下文件实现的具体功能 0x03 任意文件上传 =========== php/addmediadata.php 漏洞关键位置代码 data:image/s3,"s3://crabby-images/53d7d/53d7d8d9d2f14dfeb69b5bb0f3cf456ff13dd919" alt="13.png" 满足`$subpath`、`$fullpath`可以自定义目录,然后进行了一系列的检查如文件大小等 最后进入if条件中`move_upload_file`函数进行文件上传 构造poc data:image/s3,"s3://crabby-images/3b583/3b583613bea5b7eac5de96650c2681402ba86edc" alt="Pasted image 20220504155204.png" 访问./upload/1/5.php成功访问 data:image/s3,"s3://crabby-images/5f82a/5f82ab84ab7a9165fbb72598f0d7c0f2e6738f69" alt="Pasted image 20220504155243.png" addmediadatapath.php存在相同问题 收获两枚通杀漏洞 `php/addscenedata.php` 漏洞关键位置代码 data:image/s3,"s3://crabby-images/a604c/a604c09f72d697868a5c2888eca998b549afcf5d" alt="14.png" 不多说了 自己看 构造poc data:image/s3,"s3://crabby-images/4b36b/4b36b67bd8c6b9a4fe857b062a29d9dfdc6d5975" alt="Pasted image 20220504160756.png" 访问`./images/scene/5.php` data:image/s3,"s3://crabby-images/13cb6/13cb6b80c9052f75074439e58aaf402e8e4844c7" alt="Pasted image 20220504160941.png" 0x04 任意文件写入 =========== `$postData = $_POST['jsondata'];` 需要满足这个参数 看一下传参方式 data:image/s3,"s3://crabby-images/3916f/3916fa1832c79b71284f79617007e8d9c1a6855b" alt="Pasted image 20220504164650.png" 然后满足`$caller`,`$callee`、`$imagename`、`$imagecontent`这三个参数不为空 data:image/s3,"s3://crabby-images/aef7b/aef7bef4d4b95a4a7e0793be3f8d5454480f3493" alt="Pasted image 20220504164718.png" 满足`$imagename`用\_分割后等于三个 data:image/s3,"s3://crabby-images/6bfc5/6bfc549a32c3d4374f1429e9e1b295c6e5181421" alt="Pasted image 20220504164841.png" `$callee`参与了目录拼接 这里跨目录上传 (需要知道根目录才能解析成功) data:image/s3,"s3://crabby-images/27c63/27c6350ab9d4ca5056aad7997e55d12e302e29cb" alt="Pasted image 20220504164952.png" 只传入一串base64加密的内容 进入else条件 data:image/s3,"s3://crabby-images/35e66/35e662351b55accd1e2f0d963f370e210f18eff4" alt="Pasted image 20220504165102.png" data:image/s3,"s3://crabby-images/f036f/f036f5a9a356965206f756fb12c4edf1b23b68c4" alt="Pasted image 20220504165046.png" 构造POC data:image/s3,"s3://crabby-images/56424/5642456b7aabd4b52b6f21e53f9196073ad019a6" alt="Pasted image 20220504165137.png" 成功上传 data:image/s3,"s3://crabby-images/12527/1252793c7899c4be8b05fa5bb76ac793e16fa389" alt="Pasted image 20220504165151.png" 0x05 任意文件读取 =========== `php/exportrecord.php` 漏洞关键位置代码 data:image/s3,"s3://crabby-images/5967c/5967cc3d0b4f1bfe9d20f9343a796ad34e53b823" alt="15.png" 获取了参数`downname` 需要下载的文件进行了`urldecode` 不用管 左思右想 想了半天也也不知道为什么要在37行加个basename 直接在`41`行 执行了`fread`操作 data:image/s3,"s3://crabby-images/ac0d3/ac0d31c3245a1c52105682ef094dd84c93409cab" alt="Pasted image 20220504172319.png" 类似操作还有 `exprottts.php` data:image/s3,"s3://crabby-images/bcdb1/bcdb1f4014f919bf6ec9cf96b7fb91f038bb06d0" alt="Pasted image 20220504173126.png" 0x06 总结 ======= 此套代码几乎无过滤,这也是硬件设备的一个通病,很多厂商都以为不会"黑客"拿到源码。 还有很多漏洞 都是无过滤的 此处不一一写出来了
发表于 2022-05-10 09:44:04
阅读 ( 5898 )
分类:
漏洞分析
0 推荐
收藏
3 条评论
低级管理员
2022-05-10 10:45
还是要留点厂商线索,不然容易被骂
请先
登录
后评论
花北城
2022-05-11 11:39
下次一定
请先
登录
后评论
孤岛一L
2022-06-10 18:02
什么设备啊,想复现都找不到,透漏一点点也行啊
请先
登录
后评论
请先
登录
后评论
花北城
4 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!