[HITCON 2017]SSRFme
172.16.134.121 <?php if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) { $http_x_headers = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']); $_SERVER['REMOTE_ADDR'] = $http_x_headers[0]; }
echo $_SERVER["REMOTE_ADDR"];
$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__);
|
先去了解下代码!
php代码审计
pathinfo
<?php $path_parts = pathinfo('/www/htdocs/inc/lib.inc.php');
echo $path_parts['dirname'], "\n"; echo $path_parts['basename'], "\n"; echo $path_parts['extension'], "\n"; echo $path_parts['filename'], "\n"; ?>
|
以上例程会输出:
/www/htdocs/inc lib.inc.php php lib.inc
|
basename
返回路径中的文件名部分
$_SERVER
https://blog.csdn.net/u012222248/article/details/79816801
mkdir|chdir
和字面意思一样!😶说的太细了!
Perl 先去学学!
这个题感觉没意思!!!
不写wp了!