当前位置: 首页 > news >正文

南京培训网站建设千锋教育地址

南京培训网站建设,千锋教育地址,校园网站怎么做,网页设计代码制作表格启动场景打开链接&#xff0c;出现一下图片 F12查看代码出现一个注释&#xff0c;应该在这个文件中&#xff0c; 进入到该页面&#xff0c;出现一段代码 <?phphighlight_file(__FILE__);class emmm{public static function checkFile(&$page){$whitelist ["sourc…

启动场景打开链接,出现一下图片

F12查看代码出现一个注释,应该在这个文件中,

进入到该页面,出现一段代码

<?phphighlight_file(__FILE__);class emmm{public static function checkFile(&$page){$whitelist = ["source"=>"source.php","hint"=>"hint.php"];//定义了一个白名单,只有source.php和hint.php有新的PHP页面if (! isset($page) || !is_string($page)) {//isset就是判断$page是不是NULL,只要不是NULL返回的都是true//is_string就是判断是不是字符串,是的话返回true,但是要注意前面有!,所以是取反//所以只要传入的数据是字符串就不会返回falseecho "you can't see it";return false;}if (in_array($page, $whitelist)) {//in_array()函数搜索数组中是否存在制定的值//这个函数是判断$page是否在白名单$whitelist里面,而我们只能传入source.php或者hint.php,但是我们要获取flag肯定要输入其他字符,所以往下继续看return true;}//在$page?里面匹配第一个问号//例如$page=123?45,$page . '?'=123?45? 返回int(3)$_page=123$_page = mb_substr($page,0,mb_strpos($page . '?', '?'));//这个if语句也是判断$_page是否在白名单内,无法绕过if (in_array($_page, $whitelist)) {return true;}$_page = urldecode($page);$_page = mb_substr(//mb_substr()函数返回字符串的一部分$_page,0,mb_strpos($_page . '?', '?')   //mb_strpos - 查找字符串在另一字符串中首次出现的位置);if (in_array($_page, $whitelist)) {return true;}echo "you can't see it";return false;}}if (! empty($_REQUEST['file'])                 //传入的参数不为空&& is_string($_REQUEST['file'])           //传入的参数为字符串&& emmm::checkFile($_REQUEST['file'])    //让这个类checkFile返回true) {include $_REQUEST['file'];exit;} else {echo "<img src=\"https://i.loli.net/2018/11/01/5bdb0d93dc794.jpg\" />";}  ?>

这段PHP代码定义了一个名为emmm的类,其中包含一个静态方法checkFile。这个方法的作用是检查请求的文件名是否在一个白名单内,即$whitelist数组中列出的几个文件(如"source.php"、“hint.php”)。如果文件名在列表中或者经过URL解码处理后仍在列表中,方法返回true,表示可以访问该文件;否则返回false,并显示"You can’t see it"的信息。

在主程序部分,它首先检查$_REQUEST['file']变量是否存在、是否为字符串,然后调用emm::checkFile()方法。如果检查通过,就包含并执行指定的文件;如果没有通过检查,则显示一个图片链接。

先构造?file=hint.php

进入到其中出现以下情况

所以flag应该是在ffffllllaaaagggg这个文件里

构造payload:source.php?file=source.php?/../ffffllllaaaagggg,经过mb_strpos为source.php?/../ffffllllaaaagggg?,mb_strpos这个函数只返回首次出现?的位置,而mb_substr截取函数,从0开始截取一直到第一个?的位置,截取内容为source.php,正好可以与白名单中进行匹配,可以返回true

然后执行payload,发现没有显示flag,所以应该不是这个目录,继续加../,直到得到flag

payload:/source.php?file=source.php?/../../../../ffffllllaaaagggg

http://www.dinnco.com/news/55596.html

相关文章:

  • 设计理念网站搜索引擎优化培训中心
  • 黄冈市建设委员会网站推广信息发布平台
  • 临沂网站建设培训学校湖南网站营销推广
  • 天津国际工程建设监理公司网站seo公司 杭州
  • 阳泉软件定制网站建设店铺运营
  • wap网站案例黑帽seo排名
  • 做英语作业的网站南宁百度快速排名优化
  • wordpress文章喜欢什么是seo站内优化
  • 网站建设 无锡百度收录批量提交入口
  • 2015做那些网站能致富河南百度关键词优化排名软件
  • 达州市住房和城乡建设局网站seo关键词排名优化是什么
  • 建网站免费吗今日西安头条最新消息
  • 做网站官网需多少钱百度搜不干净的东西
  • 网站建设喀什百度文库个人登录
  • 做返利网站如何操作流程公众号如何推广运营
  • 网站定制 div css 手工广州企业网站建设
  • 建成局网站建设上海网站营销seo电话
  • 如何通过psd做网站招商外包公司
  • 南昌哪里有建设网站的pc网站优化排名软件
  • 网站设计这个专业怎么样麒麟seo软件
  • 天津做网站就到徽信xiala5一个自己的网站
  • 台州网站推广西安百度公司开户
  • 呼和浩特做网站的公司有哪些百度网盘app官网
  • 怎么做学校网站和微信公众号软件开发流程八个步骤
  • 新开最好的传奇网站茂名网站建设制作
  • 怎样做动态网站seo关键词挖掘
  • 网站制作com百度官网首页
  • 罗湖商城网站设计推荐今日热点新闻头条
  • 自动做PPT的网站专业外贸网络推广
  • 网站建设的步骤过程百度网站的网址是什么