PHP黑魔法之md5绕过

php本身是一种弱语言,这个特性决定了它的两个特点:

  • 输入的参数都是当作字符串处理
  • 变量类型不需要声明,大部分时候都是通过函数进行类型转化

php中的判断有两种:

  1. 松散比较:只需要值相同即可,类型不必相同,不通类型比较会先转化为同类型,比如全数字字符串和数字比较,会比较两个变量的数字值是否相同。
  2. 严格比较:类型和值都要比较,有一个不相等则不相等

在两种情况下,会导致变量原值不同但 md5 或 sha1 相同

1、md5值以 0e 开头的全部相等(==判断)

原理:0 的多少次方都等于零,因此当两个数的md5值都以为0e开头时,宽松判断会相等

示例:240610708和ONKCDZ0的md5值相似,但并不相同,在"=="相等操作符的运算下,结果会返回true(sha1和Md5一样)

2、数组绕过(===判断 或 ==判断)

原理:md5和sha1对一个数组进行加密将返回NULL;而NULL===NULL返回true,所以可绕过判断

示例:

<?php
    if($_GET['a'] !== $_GET['b']){
        if(md5($_GET['a']) === md5($_GET['b'])){
            echo "flag";
        }
    }
?>

?a[]=1&b[]=2

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

魏大橙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值