码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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,所以可绕过判断

    示例:

    1. if($_GET['a'] !== $_GET['b']){
    2. if(md5($_GET['a']) === md5($_GET['b'])){
    3. echo "flag";
    4. }
    5. }
    6. ?>

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

  • 相关阅读:
    docker-network网络
    【BOOST C++ String专题02】数字和字符串转化
    JAVA总结笔记
    李宏毅《机器学习》丨5. Tips for neural network design(神经网络设计技巧)
    从能用到好用,国产CPU不是你想象中的样子了?
    ansible介绍、主机清单、临时命令的使用
    Websocket搭建(Vue+Springboot)
    计算机毕业设计Java校园食堂订餐系统(源码+系统+mysql数据库+Lw文档)
    AI中英文翻译软件,一键批量多语种翻译
    跨境电商品牌如何制定成功的聊天机器人策略
  • 原文地址:https://blog.csdn.net/Thewei666/article/details/138870987
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号