攻防世界--simple php,easy php

本文详细介绍了在攻防世界平台中遇到的两个PHP挑战,包括simple php和easy php。在simple php中,通过弱类型比较获取flag部分值,然后利用数字加字母混合方式绕过限制。在easy php中,通过科学计数法和MD5匹配解决a和b的条件,同时利用array_search的弱类型比较特性绕过c的检查,最终构造有效payload完成挑战。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

simple php

easy php


simple php

进入环境,

查看代码我们可以清楚,这个页面可以传输ab两个参数,首先a的值为0且a为真会输出flag变量,然后判断变量b是否为数字或数字字符串,若是便退出程序,最后判断b的值是否比1234大,若是则输出flag2的值。

 在php中,‘=’表示赋值;‘==’表示等于运算,但是不比较值的类型,属于弱类型比较,且对于所有0e开头的都相等;‘===’完全等于运算,比较值和类型,两者一致为真。例:$a=123,$b='123'则$a==$b为真  $a===$b为假。弱类型比较中‘12a’==12

弱类型比较就是将两个变量转换为相同的类型,然后进行比较,若是转为数字型,则看字符串前的数字是几就是几。

因此我们可以使用==对a进行一个赋值,

输入a==0成功拿到前半截flag值,再来绕过参数b,首先我们需要赋值给参数b一个非数值型的字符串同时参数值要大于1234&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值