安恒杯十二月月赛WriteUP

WEB

0x01 ezweb2

访问主页抓包发现存在cookie值,其中uesr为base64加密解密后发现值同为user。

cookie

将其值修改为admin的base64加密后的值进行访问,发现页面重定向到了admin.php页面。

重定向

通过访问并抓包发现可以直接输入CMD命令

后台

输入ls发现返回当前目录中的文件,但输入ls /确出现错误。

image.png

无法使用空格,通过cat<config.php命令查看config.php文件,发现该文件将cmd传入的部分字符都替换成了空。

替换

在linux中空格可以使用$IFS代替空格。利用ls$IFS/查看/目录下文件发现flag文件。

image.png

通过cat$IFS/ffLAG_404获得flag。

flag1

0x02 easy

<?php  
@error_reporting(1); 
include ‘flag.php‘;
class baby 
{   
    public $file;
    function __toString()      
    {          
        if(isset($this->file)) 
        {
            $filename = "./{$this->file}";        
            if (file_get_contents($filename))         
            {              
                return file_get_contents($filename); 
            } 
        }     
    }  
}  
if (isset($_GET[‘data‘]))  
{ 
    $data = $_GET[‘data‘];
    preg_match(‘/[oc]:\d+:/i‘,$data,$matches);
    if(count($matches))
    {
        die(‘Hacker!‘);
    }
    else
    {
        $good = unserialize($data);
        echo $good;
    }     
} 
else 
{ 
    highlight_file("./index.php"); 
} 
?>

代码审计的题目:
第一部分,分定义了一个baby的类,$file可以传入一个文件名,将该文件读入一个字符串并返回打印出来。(其中提示了flag位于flag.php文件中)
第二部分,可以利用get的方式传入data参数,对参数进行正则匹配,符合正则显示hacker!,不符合正则可以对baby类进行反序列化。

解题部分:
第一步,对baby类将需要的$file变量参数flag.php传入进行序列化。得到序列化后的字符串O:4:"baby":1:{s:4:"file";s:8:"flag.php";}。

<?php  
@error_reporting(1); 
include ‘flag.php‘;
class baby 
{   
    public $file="flag.php";
    function __toString()      
    {          
        if(isset($this->file)) 
        {
            $filename = "./{$this->file}";        
            if (file_get_contents($filename))         
            {              
                return file_get_contents($filename); 
            } 
        }     
    }  

$a = new baby();
print_r(serialize($a));
>

第二步,绕过正则表达式preg_match(‘/[oc]:\d+:/i‘,$data,$matches);正则中写到不能以大小的O/C字符开头后面接:再接正整数。现在我们序列化字符串O:4:"baby":1:{s:4:"file";s:8:"flag.php";}正好符合大写O开头后面为:再后面为正整数4。

在PHP源码var_unserializer.c,对反序列化字符串进行处理,在代码568行对字符进行判断,并调用相应的函数进行处理,当字符为'O'时,调用 yy13 函数,在 yy13 函数中,对‘O‘字符的下一个字符进行判断,如果是':',则调用 yy17 函数,如果不是则调用 yy3 函数,直接return 0,结束反序列化。接着看 yy17 函数。通过观察yybm[]数组可知,第一个if判断是否为数字,如果为数字则跳转到 yy20 函数,第二个判断如果是'+'号则跳转到 yy19 ,在 yy19 中,继续对 +号 后面的字符进行判断,如果为数字则跳转到 yy20 ,如果不是则跳转到 yy18 , y18 最终跳转到 yy3 ,退出反序列化流程。由此,在'O:',后面可以增加'+',用来绕过正则判断。(摘自红日攻防实验室http://sec-redclub.com/archives/962/

反序列化

通过将序列化的字符串修改为O:+4:"baby":1:{s:4:"file";s:8:"flag.php";},并使用get方式以data作为参数上传后得到flag。

MISC

0x01变换的指纹

0x02 签到

关注公众号,发送flag,回答问题,世界上什么牛不会跑,回答蜗牛获得flag。

0x03学习资料

下载后得到压缩包5c19f90d2677e,通过解压获得加密压缩包“只要学不死就往死里学”及“备忘录”,通过rar打开两个压缩包比较发现两个压缩包都包含同一文件备忘录,并且他们的CRC32校验都同为AB42C601。

获得压缩包

可以对解压出来的备忘录进行重新压缩,并使用ARCHPR对加密压缩包“只要学不死就往死里学”进行明文破解。

archpr

4个半小时后,终于解密到第十位获得密码1qazmko098。

得到密码

输入密码解压后得到学习资料。

5年高考3年模拟

通过把修改后缀为zip用rar打开后通过查找到world下的document.xml获得flag。

flag3

0x04 JUJU

题目提示说女朋友问我这11只JUJU哪只好看?(flag中的字符串md5后提交)
下载图片发现图片中只有几个猪,哪有11只。

JUJU

通过winhex打开,通过修改图片的高度及宽度还原图片的真实尺寸。修改宽度发现图片变花,可以修改高度还原图片,最后发现高度为00000438为真实图片高度。

hex

还原的图片获得字符串MZWGCZ33GQZTQMTEM5SGMMTEPU====

真实图片

该字符串末尾为=属于base加密,密文只包括大写字母及数字,属于base32加密,通过解密获得flag{4382dgdf2d}。

flag3

题目提示需要对flag进行md5加密,加密后得到a213072327f762855e475779eb081ca3

PWN

0x01 messageb0x

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352

推荐阅读更多精彩内容