文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

攻防世界web新手区easyphp题解writeup

2023-09-01 12:45

关注

       最近在学习CTF web相关知识,顺带学习php,在攻防世界平台上做做题。遇到了一道名为easyphp的题目,对我这个新手一点也不easy,于是决定把过程记录下来。   

      参考了官网上shuita111师傅的WP,这里主要写得更加完整详细一些。

       首先看代码,大概能够看出需要咱们传入的a、b、c满足中间那些条件,然后可以获得key1和key2,最后得到flag。

 6000000 && strlen($a) <= 3){    if(isset($b) && '8b184b' === substr(md5($b),-6,6)){        $key1 = 1;        }else{            die("Emmm...åæ³æ³");        }    }else{    die("Emmm...");}$c=(array)json_decode(@$_GET['c']);if(is_array($c) && !is_numeric(@$c["m"]) && $c["m"] > 2022){    if(is_array(@$c["n"]) && count($c["n"]) == 2 && is_array($c["n"][0])){        $d = array_search("DGGJ", $c["n"]);        $d === false?die("no..."):NULL;        foreach($c["n"] as $key=>$val){            $val==="DGGJ"?die("no......"):NULL;        }        $key2 = 1;    }else{        die("no hack");    }}else{    die("no");}if($key1 && $key2){    include "Hgfks.php";    echo "You're right"."\n";    echo $flag;}?> Emmm...

条件1:这里对提交的a需要满足a非空 且 a的数值大于该数 且 a的长度不超过3。

if(isset($a) && intval($a) > 6000000 && strlen($a) <= 3)


分析思路:intval函数就是将我们输入的字符串类型转化成整数,这里可以查看php intval函数的用法(根据菜鸟教程intval(‘1e5’)输出的是1,但我测试了下实际输出和php版本有关,另外在官网找到一个相同的Notes httpfs://www.php.net/manual/en/function.intval也是一个例子。在题目中例如intval(‘1e5’)就是10000。因此,科学计数法表示的1e7/8/9可以满足上述三个条件。

条件2:这里对提交的b需要满足b非空,并且b的md5值的倒数6位为8b184b。

if(isset($b) && '8b184b' === substr(md5($b),-6,6))

 这个没什么妙招,只能写个脚本进行爆破了,最后发现md5(53724)符合条件。

        变量c也需要我们get上去,但是需要json格式。在确定了之后进行json编码即可。

条件1:c非空 且 不是数值类型(前面有个感叹号) 且 c的m键值要大于2022。

$c=(array)json_decode(@$_GET['c']);if(is_array($c) && !is_numeric(@$c["m"]) && $c["m"] > 2022)

分析思路:这里主要考察is_numeric函数的用法,is_numeric在php中判断参数是否是数值类型是否是数字或数字字符串。注意is_numeric("a123")返回false,is_numeric("123a")也返回false;单看这里还不能下结论。

再看后面,c的m键值后面还要做比较,因此不能直接简单构造一个is_numreric为false的字符串。例如,'123a'和一个整数作比较时,它会转换成123;'a123'和整数作比较时,由于第一个位置是a,非整数,php则规定其值为0,即变成了0和123比较(关于这个部分可以参考 php中字符串和整数比较 相关知识)。于是可以构造出一个c:{"m":"12345a"}等等。

条件2:c还有个n键,其值是一个array类型,大小为2,并且第一个元素是一个数组类型。即类似于:[[*,*...],*]。

if(is_array(@$c["n"]) && count($c["n"]) == 2 && is_array($c["n"][0])){        $d = array_search("DGGJ", $c["n"]);        $d === false?die("no..."):NULL;        foreach($c["n"] as $key=>$val){            $val==="DGGJ"?die("no......"):NULL;        }        $key2 = 1;    }else{        die("no hack");

分析思路:后面语句查找n键中是否有字符串'DGGJ',如果找到指定的键值,则返回对应的键名,否则返回 FALSE。看到这里,?:运算符找不到的情况下直接die(退出),因此这里应该让它找到,故n键第二个值为'DGGJ'。

但是,后面foreach遍历时候有'DGGJ'反而直接die,看到这里,发现这两个是矛盾的。

这个问题想了半天,最后终于明白了。回到array_search函数,查找是否有,那不就是比较吗!而且前文说到将一个字符串和一整数比较时会将字符串向整数转化,这个'DGGJ'一点整数的影子都找不到,因此只能判断为0。由此可知,第一种思路直接在c的第二个位置填上字符串'DGGJ'比较成功,第二种思路填一个数字0比较成功。第一种思路前面已经pass,因此选择第二种思路。

最后根据json编码格式对c进行编码即可。

到此为止,就已经执行完了key1和key2的赋值语句,顺着下去直接可以得到flag。

最终构造的payload:http://ip:port/?a=1e9&b=53724&c={"m":"12345a","n":[[0,1,2],0]}

来源地址:https://blog.csdn.net/weixin_46906325/article/details/127154789

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯