代码审计(若干类型)(2)

空白符问题

在这里插入图片描述

is_numeric()空白符跳过问题

在is_numeric()函数中存在空白符跳过问题在这里插入图片描述
效果如下
在这里插入图片描述
在这里可加入的为" “,”\r","\n","\t","\v","\f"

trim()

在这里插入图片描述
在这里,此函数会去除" “,”\t","\n","\r","\0","\x0B"
以上就可以绕过第一个判断是否为数值的条件了。

下面,我们继续看下面的几个if else,我们要了解的是intval()和strval()

intval()

在这里插入图片描述
其成功时返回var的int值,失败返回0。空的array返回0,非空的返回1。最重要的是,intval最大的值取决于操作系统。 32 位系统最大带符号的 integer 范围是 -2147483648 到 2147483647。64 位系统上,最大带符号的 integer 值是 9223372036854775807。

最后的payload:?number=0.00%00 或?number=0.00%00 或 ?number=9223372036854775807%00
后面的%00也可以换为%20
这个题我没有复现成功,不知道是什么原因。。。但是思路是这样子的。

伪随机数

mt_rand

在这里插入图片描述

mt_srand

在这里插入图片描述
这里会产生一个安全问题,例如我们在用mt_srand()函数播种种子后,生成的随机数都是相同的。这样就可以通过逆推mt_rand()函数的种子来获取另外一个随机数的值,这里推荐工具:php_mt_seed,github上都有,就不放链接了。一般可配合文件包含来做,详情可点击

运算符

在这里插入图片描述
很简单的一个逻辑,这里我们给出运算符的优先级表格
在这里插入图片描述
然后仔细看表格的内容,大体就可以看到构造出了payload了,payload:?a=1

Parse_url

贴心的贴出语法
在这里插入图片描述
注意返回值,null在弱类型中可以利用

在这里插入图片描述
来看例题
在这里插入图片描述
我们可以看到第一个,第二个和第三个if判断里,限制了我们输入_,0,数字及字母等;我们再看下面的if判断,很明显是不能有数字的,所以我们只能通过在给url这个变量赋值时,使其变为null,则可以进行绕过。payload:_=d或.=d

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值