攻防世界 web simple_php

打开题目,是一段php代码。

进行代码审计,发现,该程序以get方式接收a,b两个变量。而flag由两部分组成,分别受制于a,b。

对于a,当$a==0并且$a时会输出flag。对于b,当is_numeric($b) 不成立且b>1234使输出。

虽然看似不太可能,但php中用==进行判断(又叫弱类型比较)时会自动进行类型转换,而产生很多问题。

对于纯字母的字符串与数字比较时,会将字母视为0,如‘abc’==0

而在字母前存在数字时,它的值仅等于前面的数字,如‘111a’==111

但是is_number(‘111a’)的返回值为否,以此我们可以对a,b进行构造:

a=a,b=9999a,即可得到flag

Cyberpeace{647E37C7627CC3E4019EC69324F66C7C} 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值