zoukankan      html  css  js  c++  java
  • 关于_tostring[php]的另类利用

    收获

    反序列化tostring的考点不一定要考察调用一个Class,也可以使用echo来进行考察

    tostring()方法:在直接输出对象引用的时候,就不会产生错误,而是自动调用了__tostring()方法,输出__tostring()方法中返回的字符串

    通俗来说就是 对象一般是使用print_r() 或 var_dump() 来打印访问

    但对于一般闲的人来说直接 使用 echo 输出对象时,必定会报错的,原因是对象无法使用echo的。

    这个时候如果想解决这个错误,咱们应该怎么操作呢?

    可以很好的利用__tostring()这个魔术方法

    但是切记使用__toString() 时返回值一定要使用return 来进行返回。

    <?php
    
    class Flag{
        public $file;
        function __tostring(){
            if(isset($this->file)){
                echo $this->file;
            }
            return ' ';
        }
    }
    $y='O:4:"Flag":1:{s:4:"file";O:4:"Flag":1:{s:4:"file";s:8:"flag.php";}}';
    $x='O:4:"Flag":1:{s:4:"file";s:8:"flag.php";}';
    echo unserialize($x);
    echo unserialize($y);
    ?>
    
    
    flag.php flag.php  
    进程已结束,退出代码 0
    

    无报错,且返回都是flag.php

    <?php
    
    class Flag{
        public $file;
    }
    $y='O:4:"Flag":1:{s:4:"file";O:4:"Flag":1:{s:4:"file";s:8:"flag.php";}}';
    $x='O:4:"Flag":1:{s:4:"file";s:8:"flag.php";}';
    echo unserialize($x);
    echo unserialize($y);
    ?>
    

    报错,无法反序列化

  • 相关阅读:
    robotframework----模板的使用
    RF执行顺序
    RobotFrameWork(四)变量运算与Evaluate
    RobotFrameWork(三)数据类型
    git 命令
    常用网站
    git 应用
    ie if判断
    移动端rem适配
    绘制三角形(sass)
  • 原文地址:https://www.cnblogs.com/LLeaves/p/12884119.html
Copyright © 2011-2022 走看看