Apache2 Ubuntu-XXE漏洞渗透
Apache2 Ubuntu Default Page 是一个包含xxe漏洞的页面,如何找到和利用xxe漏洞,并找到flag呢?
第一步:先打开其网页
当安装好虚拟机环境后,打开虚拟机我们并不知道它linux的账号密码
data:image/s3,"s3://crabby-images/be1a3/be1a3b1472a3e174e5331dde10457522d8f43ddd" alt=""
因为我们用的net模式,我们可以在本机通过ip来访问他的网站,但我们不知道他分配是哪个ip
data:image/s3,"s3://crabby-images/e3fbf/e3fbf4f40f5a014be56fabbe8316e2fb669c6f60" alt=""
只知道他在192.168.30.1-192.168.255之间,然后御剑2014端口扫描去扫描IP,发现IP为192.168.30.128是有响应。
data:image/s3,"s3://crabby-images/f888f/f888f6de3ade55b6294fe7a1704653e7c96047d5" alt=""
然后我们网页访问IP下web
data:image/s3,"s3://crabby-images/10f3f/10f3fd286a86e9525864abe9ea1cf5102b6bf36a" alt=""
翻译一下:发现Apache2的网站目录配置
data:image/s3,"s3://crabby-images/a5e7e/a5e7efbf53c8d0d6a2e28555b963261f2f4ff187" alt=""
第二步:扫描目录
我们首先要知道该网站下有哪些页面,然后在其中找有XXE的漏洞
所以首先通过御剑目录扫描来扫描目录,index.html就是网站首页,也就是上面的页面
data:image/s3,"s3://crabby-images/b3a05/b3a0560dad6ff54cc258f74c08bf2bbc2d9f7441" alt=""
打开robots.txt看看有什么东西,看见有/xxe目录,还有给admin.php
data:image/s3,"s3://crabby-images/4cb6b/4cb6b16436d6918a1341f82fdff6f58c6bf52309" alt=""
我们试一下xxe发现发现一个新网页,是/xxe/index.php
data:image/s3,"s3://crabby-images/de620/de620747b80237d5bceb6a8c04fbbd38e96f1aac" alt=""
在xxe/admin.php发现一个页面
data:image/s3,"s3://crabby-images/4c55b/4c55b3e5bed412b394370da1ba5fdd3b1ea7218d" alt=""
在index.php随便输入点东西发现回显点
data:image/s3,"s3://crabby-images/5a23f/5a23fb6a4083fec791506320c2cb66faf58d1e61" alt=""
步骤三:抓包
data:image/s3,"s3://crabby-images/7b680/7b68041dc925b5f1f28043738a601e9e9db13aa0" alt=""
我们构造xxe语句将&xxe;指向/etc/passwd文件,看是否有回显
data:image/s3,"s3://crabby-images/1ff60/1ff60dcf9a173e4793b34422bb0f2f0dc0773ddb" alt=""
可看到显示文件内容,说明存在xxe漏洞,那么继续查看首页文件
apache首页文件默认路径时/var/www/html/
data:image/s3,"s3://crabby-images/8af3a/8af3a8627166eca87511d614e9afb2b8744c157a" alt=""
发现错误,然后我们用php协议查看php文件
data:image/s3,"s3://crabby-images/b9b46/b9b464fc28e0e258b684f2c55f13d4f9dcf33288" alt=""
复制解码
data:image/s3,"s3://crabby-images/209bf/209bfa08a29877052bdbe273cbe8a3fbf517662f" alt=""
发现没有可用的
然后看admin.php
data:image/s3,"s3://crabby-images/3f443/3f443dae86272975b65e2863b2f129f744f6addd" alt=""
解码后,发现用户名密码,用户名:administhebest,密码是加密过的
data:image/s3,"s3://crabby-images/65998/65998270b8b3f4b17683bbceabd83a4315a7a501" alt=""
这串数字是md5加密,所以md5解密发现密码是admin@123
data:image/s3,"s3://crabby-images/9a311/9a311402aee3780c6ddad00763bccbe7c3b48192" alt=""
在admin.php登录:
data:image/s3,"s3://crabby-images/37e46/37e46765556190a809976e388b669837a5de9fbf" alt=""
data:image/s3,"s3://crabby-images/b045d/b045dc5c5ab491746eb15a8bda52f3c4c123e30b" alt=""
发现没有,有点崩溃!!
data:image/s3,"s3://crabby-images/c9dd5/c9dd58b725a43887f831f19eeec96ea5d2a492eb" alt=""
然后发现出现了另一个php文件,存在即合理。那就看看这个php文件到底在哪里,然后发现再xxe里
data:image/s3,"s3://crabby-images/53ac5/53ac5b5af5efe169f7170862445ab6d7e032a824" alt=""
右键查看源代码
data:image/s3,"s3://crabby-images/dfd0a/dfd0aa6b3fcc8056eb3c658758c4ba6d1d8534d2" alt=""
然后32位解码再64位解码
data:image/s3,"s3://crabby-images/5fd93/5fd9374400b6303c408b7e7d2ede9ba4bb9cf081" alt=""
data:image/s3,"s3://crabby-images/ede12/ede12ea889f62b0ccfcee0e85b76c893b14e3fe9" alt=""
再次抓包
<!DOCTYPE root [
<!ENTITY xxe SYSTEM "file:///etc/.flag.php"> ]>
data:image/s3,"s3://crabby-images/df609/df609b0543450fa508c73022468ffa6f2024e1bd" alt=""
放到php文件运行
data:image/s3,"s3://crabby-images/1d7b7/1d7b7870e92a679eb496ae0fb6fb549b25d13cfb" alt=""
然后发现答案
data:image/s3,"s3://crabby-images/a4bbf/a4bbf6e0793235f2f3a0afc7431a7b43f731f0d3" alt=""