zoukankan      html  css  js  c++  java
  • PHP黑魔法(该篇文章转自:http://www.91ri.org/12634.html 目的是作为自己的笔记方便查找)

    那些年我们学过的PHP黑魔法

                                                                                                                    作者:Matrix_ling

    这里必须得说一下==和===这俩货的重要性。
    ==是比较运算,它不会去检查条件式的表达式的类型
    ===是恒等,它会检查查表达式的值与类型是否相等
    NULL,0,”0″,array()使用==和false比较时,都是会返回true的,而使用===却不会
    这个基础知识点大家应该都知道,所以提一下,下面就不会再拿出来说了。

    数组

    0x01
    很多时候,PHP数组都发挥了至关重要的作用,先来看下BOSTEN KEYPARTY中的一道题:

    这道题,我们首先要确保name和password的值不能相同,其次,sha1加密之后的name和password的值又必须完全相同 我们知道,这时的a[0] = 1;所以name[] = 1和password[]= 2相比较,可以跳过第一个判断,而如果使用sha1对一个数组进行加密,返回的将是NULL,NULL===NULL,这是成立的,所以构造两个数组,成功拿到flag

    0x02
    再看bosten keyparty上的另外一道题:

    这里,使用strcmp去比较password和flag,如果==0的话,就给出flag,但是strcmp比较,如果相等才会返回0,如果不相等的话,要么大于0,要么小于0,但是strcmp只会处理字符串参数,如果给个数组的话呢,就会返回NULL,而判断使用的是==,NULL==0是bool(true)的,所以,这道题还是一如既往构造一个数组进去

    0x03
    bosten keyparty上的又又一道题:

    这道题有两种做法,我们还是先说数组 ereg是处理字符串的,所以,按照原理,我们将password构造一个arr[],传入之后,ereg是返回NULL的,===判断NULL和FALSE,是不相等的,所以可以进入第二个判断,而strpos处理数组,也是返回NULL,注意这里的是!==,NULL!==FALSE,条件成立,拿到flag, 第二种做法,ereg读到%00的时候,就截止了,所以可以构造s%00–,也能拿到flag(这也算是一个黑魔法吗?哈哈)

    数字的比较

    0x01
    wechall上的一道题:

    这里,它不让输入1到9的数字,但是后面却让比较一串数字,平常的方法肯定就不能行事了,大家都知道计算机中的进制转换,当然也是可以拿来比较的,0x开头则表示16进制,将这串数字转换成16进制之后发现,是deadc0de,在开头加上0x,代表这个是16进制的数字,然后再和十进制的3735929054比较,答案当然是相同的,返回true拿到flag

    0x02
    看安全宝约宝妹的一道题:

    在乌云zone上,X总已经对其进行分析了

    传送门,这块是数学的东西了。。 42.00e+0000000000,10的00000次方。。等于42.000000…. 结果其实就是42,不过有时候这些东西也会出奇迹的是不是。。

    switch没有break

    在wechall上有一道题:

    让我们包含当前目录中的solution文件,这里会发现在case 0和case 1的时候,没有break,按照常规思维,应该是0比较不成功,进入比较1,然后比较2,再然后进入default,但是事实却不是这样,事实上,在case 0的时候,进入了case 0的方法体,但是却没有break,这个时候,默认判断已经比较成功了,而如果匹配成功之后,会继续执行后面的语句,这个时候,是不会再继续进行任何判断的。也就是说,我们which传入solution的时候,case 0比较进入了方法体,但是没有break,默认已经匹配成功,往下执行不再判断,进入2的时候,执行了require_once solution.php,查阅资料之后发现, 这个黑魔法是继承于C语言,paper传送阵:传送阵

    小结

    至此,就我自己遇到过的很有意思的php黑魔法就这么点了,若大家有其他猥琐的trick或者屌炸天的黑魔法,大家一起交流交流咯,无形装逼,最为致命,摸摸大。

    【via@Sco4x0

  • 相关阅读:
    Mayan游戏 (codevs 1136)题解
    虫食算 (codevs 1064)题解
    靶形数独 (codevs 1174)题解
    黑白棋游戏 (codevs 2743)题解
    神经网络 (codevs 1088) 题解
    The Rotation Game (POJ 2286) 题解
    倒水问题 (codevs 1226) 题解
    银河英雄传说 (codevs 1540) 题解
    生日蛋糕 (codevs 1710) 题解
    第一章 1.11 高阶函数
  • 原文地址:https://www.cnblogs.com/Yuuki-/p/9010990.html
Copyright © 2011-2022 走看看