[BJDCTF2020]Easy MD5-1

尝试1'注入,没反应.然后burp抓包

发现相应的headers中的Hint

Hint: select * from 'admin' where password=md5($pass,true)

md5函数第二个参数有说法:

二进制格式输出会出现乱码,如果乱码为    'or'

比如:ffifdyop经过md5加密后为:276f722736c95d99e921722cf9ed621c

再转换为字符串:'or’6<乱码>

select * from 'admin' where password=''or’6<乱码>'

条件永真

输入ffifdyop后跳转至:

查看源代码

md5相等绕过

1.0E

因为处理hash字符串时,PHP会将每一个以 0E开头的哈希值解释为0,那么只要传入的不同字符串经过哈希以后是以 0E开头的,那么PHP会认为它们相同 (== 的结果为 True,但 === 的结果为 False)

2.数组绕过

在 PHP5 和 PHP7 中,当两个 md5 进行比较时,若参数是不同的数组,那么 == 和 === 比较的结果均为 True

3.md5碰撞

参考链接:https://www.cnblogs.com/ainsliaea/p/15126218.html

采用数组绕过:

跳转至:

采用数组绕过:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值