buuctf warmup 超详细

news2025/1/15 13:29:30

目录

1.代码审计:

2.逻辑分析

3.总结分析

4.分析记录

5.疑点解答


1.代码审计:

<?php
    highlight_file(__FILE__);
    class emmm                          //定义了一个类
    {
        public static function checkFile(&$page)          类里面又申明创建了一个函数
        {
            $whitelist = ["source"=>"source.php","hint"=>"hint.php"]; //创建了一个白名单字典,在php当中字典就是一种具有映射关系的数组。
            if (! isset($page) || !is_string($page)) {    //如果没有设置page的值或者说page不是字符串,那么就return 为假
			
                echo "you can't see it";                    
                return false;
            }

            if (in_array($page, $whitelist)) {   //使用in_array函数,判断某个元素是否在数组当中,这里是字典的话,就是判断某个值是否在数组当中存在,注意,字典只会判断某个值
												//是否在字典当中存在,也就是说查找的是值,而不是键				
                return true;                     //返回真
            }

            $_page = mb_substr(              //mb_substr和substr的功能大致都是一致的,用来截取子串,但是mb有个特点就是,它可以指定字符编码,在处理非英文字符时会比较好
			                                 //substr(主串,start,length) ,start为开始下标,从0开始
                $page,
                0,
                mb_strpos($page . '?', '?')       //strpos用来查找指定字符在主串当中第一次出现的下标位置,strpos(主串,要查找的字符,可选参数,起始下标)
            );
            if (in_array($_page, $whitelist)) {
                return true;                     //返回真
            }

            $_page = urldecode($page);          //url解码之后的参数赋值给一个新的变量
            $_page = mb_substr(
                $_page,                       
                0,
                mb_strpos($_page . '?', '?')        // 先把原有的参数和?进行拼接,再查找?的序号
            );
            if (in_array($_page, $whitelist)) {       判断page的值是否在whilelist这个字典的值当中存在,注意是只查找值不是键
                return true;                       // return 真
            }
            echo "you can't see it";
            return false;                        //否则返回假
        }
    }

    if (! empty($_REQUEST['file'])                  //主题部分,通过file传递参数非空并且file的值为字符串并且对file调用上面类中的方法返回值为真
	                                               //这三个条件同时满足,才会进入到下一步
        && is_string($_REQUEST['file'])
        && emmm::checkFile($_REQUEST['file'])
    ) {
        include $_REQUEST['file'];            //把传入的字符串进行文件包含,include函数会把一个文件包含进来并且执行就是说我们要传递的file是一个文件名或者说是服务器当中的一个文件路径更加准确,然后这里会把它
		//就是说我们要传递的file是一个文件名或者说是服务器当中的一个文件路径更加准确,然后这里会把它
         exit;								//进行包含进来。本题的关键就是在这里,就是通过传递文件名,进行文件包含,包含存在flag的文件,那么我们就可以得到flag了
    } else {
        echo "<br><img src=\"https://i.loli.net/2018/11/01/5bdb0d93dc794.jpg\" />";
    }  
?>   

2.逻辑分析

我们通过在get请求当中构造file参数,参数得是字符串,还要满足check函数,才会执行下面的内容,把文件给包含执行进来
根据提示 找到flag信息  但是直接访问不行 因为进入到check函数会执行到最后返回flase


所以说给的flag信息路径应该不是直接访问的,应该存在着某种相对路径

但是我们构造的路径当中还要包含白名单当中的内容才可以返回true
check函数有很多种可能会返回真值,所以要进行构造
但是直接拼接../../../不行 不满足true
所以在前面加上source试试还是不行,考虑他这里check函数会在尾部拼接问号,但是直接在尾部拼接问号在结合strpos和substr得到的还是原来的字符串
每一个if都会判断是不是在白名单当中,必须要在白名单当中才会返回true ,又因为他有strpos函数去定位?的位置再去截取之后再判断
所以我们可以构造一个? 使得它在被截取之后是白名单的内容
所以 尝试自己构造问号  source.php?../../ffffllllaaaagggg

这样的话再执行check函数的时候
这里可以返回true

3.总结分析

涉及到的代码审计,而且比较考验思维,还有就是要熟悉php的常见函数

4.分析记录

 <?php
    highlight_file(__FILE__);
    class emmm                          //定义了一个类
    {
        public static function checkFile(&$page)          类里面又申明创建了一个函数
        {
            $whitelist = ["source"=>"source.php","hint"=>"hint.php"]; //创建了一个白名单字典,在php当中字典就是一种具有映射关系的数组。
            if (! isset($page) || !is_string($page)) {    //如果没有设置page的值或者说page不是字符串,那么就return 为假
            
                echo "you can't see it";                    
                return false;
            }

            if (in_array($page, $whitelist)) {   //使用in_array函数,判断某个元素是否在数组当中,这里是字典的话,就是判断某个值是否在数组当中存在,注意,字典只会判断某个值
                                                //是否在字典当中存在,也就是说查找的是值,而不是键                
                return true;                     //返回真
            }

            $_page = mb_substr(              //mb_substr和substr的功能大致都是一致的,用来截取子串,但是mb有个特点就是,它可以指定字符编码,在处理非英文字符时会比较好
                                             //substr(主串,start,length) ,start为开始下标,从0开始
                $page,
                0,
                mb_strpos($page . '?', '?')       //strpos用来查找指定字符在主串当中第一次出现的下标位置,strpos(主串,要查找的字符,可选参数,起始下标)
            );
            if (in_array($_page, $whitelist)) {
                return true;                     //返回真
            }

            $_page = urldecode($page);          //url解码之后的参数赋值给一个新的变量
            $_page = mb_substr(
                $_page,                       
                0,
                mb_strpos($_page . '?', '?')        // 先把原有的参数和?进行拼接,再查找?的序号
            );
            if (in_array($_page, $whitelist)) {       判断page的值是否在whilelist这个字典的值当中存在,注意是只查找值不是键
                return true;                       // return 真
            }
            echo "you can't see it";
            return false;                        //否则返回假
        }
    }

    if (! empty($_REQUEST['file'])                  //主题部分,通过file传递参数非空并且file的值为字符串并且对file调用上面类中的方法返回值为真
                                                   //这三个条件同时满足,才会进入到下一步
        && is_string($_REQUEST['file'])
        && emmm::checkFile($_REQUEST['file'])
    ) {
        include $_REQUEST['file'];            //把传入的字符串进行文件包含,include函数会把一个文件包含进来并且执行就是说我们要传递的file是一个文件名或者说是服务器当中的一个文件路径更加准确,然后这里会把它
        //就是说我们要传递的file是一个文件名或者说是服务器当中的一个文件路径更加准确,然后这里会把它
         exit;                                //进行包含进来。本题的关键就是在这里,就是通过传递文件名,进行文件包含,包含存在flag的文件,那么我们就可以得到flag了
    } else {
        echo "<br><img src=\"https://i.loli.net/2018/11/01/5bdb0d93dc794.jpg\" />";
    }  
?>  

5.疑点解答

我相信很多人和我会有一个疑问,就是明明page当中有一个问号,那么在文件包含的时候是怎样包含到后面的内容的呢。

我也想了好久,最后了解到一个php当中include、require函数在进行文件包含的时候,有这样一个规则:在PHP中,当使用include函数引入文件时,如果文件路径中包含查询字符串,PHP会忽略查询字符串部分,只解析文件路径部分。 那什么是参数当中的路径部分呢?就是只包括文件名称和路径分隔符,或者由他们组成的整体,如果有问号?那么就在?后面查找文件路径,问号就是查询字符串,也就是说只会查找符合格式的文件路径。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1519435.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

稀碎从零算法笔记Day18-LeetCode:移除链表元素

前言&#xff1a;接近20day的时间&#xff0c;终于来到了链表。 题型&#xff1a;指针、链表 链接&#xff1a;203. 移除链表元素 - 力扣&#xff08;LeetCode&#xff09; 来源&#xff1a;LeetCode 题目描述 给你一个链表的头节点 head 和一个整数 val &#xff0c;请你…

UE4_AI_行为树_行为树快速入门指南

声明&#xff1a;学习笔记。 在 行为树快速入门指南 中&#xff0c;你将学会如何创建一个敌方AI&#xff0c;该AI看到玩家后会做出反应并展开追逐。当玩家离开视线后&#xff0c;AI将在几秒钟后&#xff08;这可根据你的需求进行调整&#xff09;放弃追逐&#xff0c;并在场景中…

P1086 [NOIP2004 普及组] 花生采摘

题目描述 鲁宾逊先生有一只宠物猴&#xff0c;名叫多多。这天&#xff0c;他们两个正沿着乡间小路散步&#xff0c;突然发现路边的告示牌上贴着一张小小的纸条&#xff1a;“欢迎免费品尝我种的花生&#xff01;――熊字”。 鲁宾逊先生和多多都很开心&#xff0c;因为花生正…

xnip滚动截图失效

出现问题背景 系统&#xff1a;macos 截图区域&#xff1a;iterm终端 问题原因 截图背景为非纯色背景&#xff0c;我在iterm中的背景设置了图片&#xff0c;即使用图片作为终端背景&#xff0c;而xnip不支持非纯色背景的滚动截图。 解决方法 取消使用图片背景。 引用 滚…

Linux编译器gcc/g++的功能与使用

一、程序的生成 首先&#xff0c;我们知道程序的编译分为四步&#xff1a; 1、预处理 2、编译 3、汇编 4、链接 1.1预处理 预处理功能主要包括头文件展开、宏定义、文件包含、条件编译、去注释等。 所谓的头文件展开就是在预处理时候&#xff0c;将头文件内容拷贝至源文…

算法之二分查找算法

二分查找算法简介 1. 首先说明二分查找算法是比较恶心, 细节很多, 很容易写出死循环的算法, 但熟悉了之后是最简单的算法. 2. 其次我们可能听说过二分查找的前提是数组有序的前提下进行, 但其实不一定. 3. 二分查找算法有一套模板: 朴素的二分模板: 比较简单, 但是有局限性查找…

【Office学习】Word参考文献交叉引用之连续引用

Word中为实现连续多个参考文献的的引用&#xff0c;如[1-3] 通过交叉引用至内容中的【1】和【3】不必多说&#xff0c;关键问题是如何变成[1-3]&#xff0c;如果强行删掉两边括号&#xff0c;更新后会恢复原样不说&#xff0c;打印或者转为PDF无法识别到删除的修改。 例如 1…

北斗卫星在桥隧坡安全监测领域的应用及前景展望

北斗卫星在桥隧坡安全监测领域的应用及前景展望 北斗卫星系统是中国独立研发的卫星导航定位系统&#xff0c;具有全球覆盖、高精度定位和海量数据传输等优势。随着卫星导航技术的快速发展&#xff0c;北斗卫星在桥隧坡安全监测领域正发挥着重要的作用&#xff0c;并为相关领域…

C++ 网络编程学习五

C网络编程学习五 网络结构的更新单例模式懒汉单例模式饿汉单例模式懒汉式指针智能指针设计单例类 服务器优雅退出asio的多线程模型IOServiceasio多线程IOThreadPoolepoll 和 iocp的一些知识点 网络结构的更新 asio网络层&#xff0c;会使用io_context进行数据封装&#xff0c;…

Typora设置文本颜色

目录 总共分为三种方法 1.使用markdown语法的内联公式 2.使用HTML语法 3.借助第三方软件&#xff08;不建议&#xff0c;操作没那么顺滑&#xff09; 总共分为三种方法 1.使用markdown语法的内联公式 <1>首先需要在设置中勾选Markdown扩展语法下的内联公式&#xff…

QML| QML 组件

# | QML 组件 | 组件是可重用的、封装好的QML类型,并提供了定义好的接口。组件一般使用一个.qml文件定义。前面讲到的使用QML文档定义对象类型,其实就是创建了一个组件。这种使用独立QML文件创建组件的方法这里不再讨论。除了使用单独的QML文件,还可以使用Component类型在一…

DVWA 靶场搭建

文章目录 环境说明1 DVWA 简介2 DVWA 安装 环境说明 操作系统&#xff1a;Windows 10PHPStudy 版本: 8.1.1.3Apache 版本&#xff1a;2.4.39MySQL 版本 5.7.26 1 DVWA 简介 DVWA&#xff08;Damn Vulnerable Web App&#xff09;是一个基于 “PHP MySQL” 搭建的Web应用程序&…

【linux】进程(一)

先看预备知识&#xff0c;对本篇文章更有帮助。 目录 进程概念&#xff1a;了解动态运行的概念&#xff1a;进程的本身内部属性&#xff1a;启动进程&#xff1a;关闭进程&#xff1a; 如何创建进程&#xff1a;进程状态&#xff1a;直接看进程状态&#xff1a;僵尸进程与孤儿…

L2-002 链表去重(Python)

给定一个带整数键值的链表 L&#xff0c;你需要把其中绝对值重复的键值结点删掉。即对每个键值 K&#xff0c;只有第一个绝对值等于 K 的结点被保留。同时&#xff0c;所有被删除的结点须被保存在另一个链表上。例如给定 L 为 21→-15→-15→-7→15&#xff0c;你需要输出去重后…

golang中new和make的区别

1. 先看一个例子 package mainimport "fmt"func main() {var a *int*a 10fmt.Println(*a) }运行结果是啥呢&#xff1f; 问&#xff1a;为什么会报这个panic呢&#xff1f; 答&#xff1a;因为如果是一个引用类型&#xff0c;我们不仅要声明它&#xff0c;还要为…

林木园区改造VR仿真培训课件提高人们的专业素质

森林经营VR模拟体验摆脱了传统森林经营周期长、实践难及耗材大等问题&#xff0c;借助VR虚拟仿真技术为人们提供一种全新的、沉浸式的森林经营体验&#xff0c;让人们更好地了解森林经营的全周期。 提高人们的环保意识 通过亲身参与森林经营的过程&#xff0c;人们可以更直观地…

【学习心得】字符验证码逆向思路

一、验证码验证流程 首先在破解验证码之前&#xff0c;需要知己知彼才能百战百胜&#xff0c;所以通过下面这张图来了解一下验证码是如何起作用的。下面以登录业务为例。 &#xff08;1&#xff09;简单流程 &#xff08;2&#xff09;请求与响应数据包流程 二、破解验证码一般…

Linux中防火墙相关操作

一、查看防火墙状态 可通过两种方式查看防火墙状态&#xff0c;一种通过systemctl命令&#xff0c;另一种是通过firewall-cmd命令。 1、systemctl status firewalld 2、firewall-cmd --state 二、关闭防火墙 1、暂时关闭&#xff1a;设置暂时关闭防火墙将会在下次重启系统后失…

永热爱 敢向前 | Paraverse平行云的2023 年终总结

永热爱&#xff0c;敢向前 值此新年&#xff0c;回顾2023&#xff0c;仅以此句&#xff0c;献给所有XR产业信仰者 2023 年&#xff0c;是XR产业技术和场景承上启下的关键之年 在这场波澜壮阔的技术潮中 「Paraverse平行云」踏浪前行 已是第八个年头&#xff0c;让我们一起…

BMW配送流程:通过EDI对接VDLP

BMW的汽车配送流程始于汽车“生产结束”&#xff0c;结束于“交付给宝马经销商”。BMW与其物流服务供应商之间没有直接的接口&#xff0c;EDI信息将会通过BMW的EDI供应商提供的VDLP&#xff08;车辆分销物流平台&#xff09;进行交换。 近期我们收到来自国内某汽车行业供应商L公…