• 写在前面

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

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

  • 正文部分

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

<?php
highlight_file(__FILE__);
$key1 = 0;
$key2 = 0;$a = $_GET['a'];
$b = $_GET['b'];if(isset($a) && intval($a) > 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...
  • 第一个if块(解决a和b)

条件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)符合条件。

  • 第二个if块(解决c)

变量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]}

攻防世界web新手区easyphp题解writeup相关推荐

  1. 攻防世界-web新手区wp

    攻防世界-web新手区wp view source robots backup cookie disabled_button weak auth simple php get_post xff_ref ...

  2. 攻防世界——web新手区(全解)

    当前网络安全形式越来越严重,我国也越来越重视,现在国内乃至国际上各个网络攻防大赛层出不穷,但是练习平台却还是很稀缺,可以说目前网上能够练习的平台也就只有几家,大多数的院校它们有自己的练习平台但并不公开 ...

  3. 攻防世界web新手区(来自小白)*-*

    鄙人是个纯纯的小白,这个博客也是给小白写的,不过大佬们也不会来查这些题的wp吧 拍飞 文章目录 攻防世界WEB新手区(1--11) 第一题view_source 第二题robots 第三题backup ...

  4. 攻防世界-Web(新手区)

    前言 暑假前,为了学习Web题,做了攻防世界的新手区的Web题,当时没有总结,现在总结一下. 正文 Web1:view_source 查看源代码,右键不可以用.所以按F12,直接查看源码即可. Web ...

  5. 攻防世界web新手区合集

    攻防世界(xctf)做题合集-get_post- robots-backup-cookie-disabled_button-simple_php-weak_auth-xff_referer-simpl ...

  6. 2019攻防世界web新手区

    robots 看了题目描述,发现与robots协议有关,过完去百度robots协议.发现了robots.txt,然后去构造url访问这个文件  http://111.198.29.45:42287/r ...

  7. 攻防世界web新手区解题 /cookie / disabled_button / weak_auth

    cookie 题目描述:X老师告诉小宁他在cookie里放了些东西,小宁疑惑地想:'这是夹心饼干的意思吗?' 使用burp suite抓包查看 发现提示: look-here=cookie.php 于 ...

  8. 攻防世界web新手区解题 view_source / robots / backup

    1**. view_source** 题目描述:X老师让小宁同学查看一个网页的源代码,但小宁同学发现鼠标右键好像不管用了. f12查看源码即可发现flag 2. robots 题目描述:X老师上课讲了 ...

  9. 攻防世界web新手区前六关

    第一题view_source 鼠标无法查看网页源代码,可以利用F12来查看,flag就在网页源码中. 第二题robots 根据题目提示robots,此题考查robots协议,robots协议也叫rob ...

最新文章

  1. 怎样才能使二级网页窗口最大化
  2. exchange 2010 指定用户邮箱连接CAS服务器
  3. 在ubuntu 16.04下安装gitlab(摘抄中文官方网站)
  4. python 链表推导式 xx for xx in yy
  5. 零基础学python看什么视频-零基础自学Python是看书还是看视频?
  6. python中文叫什么意思-在python中,“~”是什么意思?
  7. 码农在墨尔本首次求职有感
  8. Leet Code OJ 219. Contains Duplicate II [Difficulty: Easy]
  9. 说好的人工智能 怎么只看到高科技玩具?
  10. 数据结构利器之私房STL(中)
  11. 今日头条的排名算法_今日头条的推荐算法原理分析
  12. HTML 教程-菜鸟教程
  13. 传递组播与广播帧:数据待传指示传递信息(DTIM)
  14. 短信中心号码iphone_如何在iPhone上阻止来自特定号码的呼叫
  15. opengl-shader学习笔记:varying变量
  16. 甘超波:NLP价值观
  17. 2011互联网大会23日在京举行 微博带您对话CEO
  18. MySQL主从状态检查
  19. Linux常用命令——pmap命令
  20. 高中数学-二项式定理以及系数和帕斯卡定理

热门文章

  1. 国内首个政务云评估机制即将发布!
  2. ES学习笔记(二):集群配置与启动 --mac环境
  3. 成都大学c语言项目综合,成都大学C语言教案设计
  4. 每日一笑 | 不忘初心,最爱扫雷~
  5. SAP UI5 表格数据如何导出成 Excel 文件(Table Export As Excel)
  6. 第一部分 思科九年 一(5)
  7. 网络安全法剑指“黑帽黑客”
  8. anaconda 安装tensorflow1.9
  9. Android关键知识点详解
  10. 眼睛糖果插件 Alien Skin Eye Candy 7.2.3.37 for Mac汉化版(10.14.1)