[HCTF 2018]WarmUp

  1. 题目:一上来给了个图片还是很懵的,于是尝试查看一下源代码:发现有提示:
  2. 于是访问source.php得到了php代码:(这里将代码和代码分析放一块)
php 复制代码
<?php
  highlight_file(__FILE__);
class emmm
  {
    public static function checkFile(&$page)
    {
      $whitelist = ["source"=>"source.php","hint"=>"hint.php"];
      //定义白名单数组,有两个值
      if (! isset($page) || !is_string($page)) {
        echo "you can't see it";
        return false;
      }
      //这段代码的意思是检查page变量是否没有被设置,并且检查是否不是字符串,满足一个就返回FALSE

      if (in_array($page, $whitelist)) {
        return true;
      }
      //如果page变量在白名单数组内,返回TRUE
      //如果不在,继续执行下面代码
      $_page = mb_substr(
        $page,
        0,
        mb_strpos($page . '?', '?')
      );
      //将page变量重新赋值为第一个?前的内容,再次检查是否在白名单里面
      if (in_array($_page, $whitelist)) {
        return true;
      }
      //如果不含问号:
      $_page = urldecode($page);//对其进行编码
      $_page = mb_substr(
        $_page,
        0,
        mb_strpos($_page . '?', '?')
      );
      //在结尾添加?重复上述操作
      if (in_array($_page, $whitelist)) {
        return true;
      }
      echo "you can't see it";
      return false;
    }
  }
//这里才是核心逻辑,请求一个file参数
if (! empty($_REQUEST['file'])//判断是否非空
    && is_string($_REQUEST['file'])//是否为字符串
    && emmm::checkFile($_REQUEST['file'])//通过两个::可以访问类的方法和属性,这里访问的是方法
   ) {
  include $_REQUEST['file'];//文件包含
  exit;
} else {
  echo "<br><img src=\"https://i.loli.net/2018/11/01/5bdb0d93dc794.jpg\" />";
}  
?> 
  1. 构造payload:?file=hint.php得到提示:但是不是直接访问:说明我们传的参数不在白名单,于是在前面加个hint或者source.php都可以,?file=hint.php?/.../.../.../.../ffffllllaaaagggg,由于不知道在哪个文件夹下,可能是多层,经过尝试发现/.../.../.../.../刚好可以得到结果
相关推荐
charlie11451419125 分钟前
通用GUI编程技术——Win32 原生编程实战(二十二)——GDI 位图操作:BitBlt、StretchBlt 与图像处理
c++·windows·学习·c·win32
2501_920627618 小时前
Flutter 框架跨平台鸿蒙开发 - 古文学习应用
学习·flutter·harmonyos
江苏世纪龙科技11 小时前
【世纪龙科技】当智能网联汽车教学遇上“数字孪生”
学习
杰尼龟36812 小时前
Convince Develop 学习笔记
笔记·学习
不早睡不改名@12 小时前
Netty源码分析---Reactor线程模型深度解析(二)
java·网络·笔记·学习·netty
Mr. G K12 小时前
越权漏洞挖掘
web安全
婷婷_17212 小时前
【PCIe验证每日学习·Day25】PCIe 电源管理机制(L0s/L1/L2/L3)全解析
网络·学习·程序人生·芯片·电源管理·pcie 验证·低功耗状态
Mr. G K12 小时前
跨域安全漏洞的挖掘方法
web安全
東雪木13 小时前
Java学习——一访问修饰符(public/protected/default/private)的权限控制本质
java·开发语言·学习·java面试
Chengbei1113 小时前
利用 LibreNMS snmpget 配置篡改实现 RCE 的完整攻击链
人工智能·web安全·网络安全·小程序·系统安全