hitcon_2017_ssrfme

hitcon_2017_ssrfme
题目:
打开环境,得到:
在这里插入图片描述

<?php 
    $sandbox = "sandbox/" . md5("orange" . $_SERVER["REMOTE_ADDR"]); 
    @mkdir($sandbox); 
    @chdir($sandbox); 

    $data = shell_exec("GET " . escapeshellarg($_GET["url"])); 
    $info = pathinfo($_GET["filename"]); 
    $dir  = str_replace(".", "", basename($info["dirname"])); 
    @mkdir($dir); 
    @chdir($dir); 
    @file_put_contents(basename($info["basename"]), $data); 
    highlight_file(__FILE__); 

接下来进行代码审计
首先先要弄清楚sandbox的位置,实际上就是sandbox/+MD5后的(orange与你的IP地址),这个IP地址直接在网上就能找到,手动进行MD5加密,访问sandbox/+(MD5加密后的值)得到:

这里有个注意事项,就是MD5加密后的是要为小写,而不是大写

在这里插入图片描述
这种情况就证明你的路径是对的,而如果出现NOT Found的话就是错的
接下来的代码就很简单了

pathinfo就是以数组的形式返回文件路径的信息

然后这一串代码就是写入文件的操作

file_put_contents(basename($info["basename"]), $data);

所以可以传入payloadurl=/&filename=yy,访问yy即可
在这里插入图片描述
看到里面有个flag
所以可以构造?url=/flag&filename=yy,访问:
在这里插入图片描述

?这一坨是个啥玩意儿???,不过这种方式应该是已经读取到了flag,但没有按正常方式显示罢了,那就试试将后面的yy改为以.txt结尾的,payload:?url=/flag&filename=yy.txt,访问得到:
在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

o3Ev

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值