安慰奖WEB 未解决

分数: 35 金币: 5
题目作者: harry
一  血: dotast
一血奖励: 2金币
解  决: 2033
提  示:
描  述:
flag{}
评论
a2cai 3年前

1. __wakeup函数当对象数量的值大于真实的就会绕过该函数。 2. 被修饰为protected和private的属性序列化后会变成%00*%00属性名,而%00不可见、 3. cat的替代函数为tac

回复 4

GitKit 3年前

当序列化字符串表示对象属性个数的值大于真实个数的属性时就会跳过__wakeup()函数的执行。

回复 0

打工人打工魂 3年前

protected属性被序列化的时候属性值会变成:%00*%00属性名,而%00是空字符,在浏览器中会显示为空,但不代表传入时能没有%00,所以最后的payload应该加上%00

回复 1

yswdlll 3年前

wakeup绕过,将属性数量修改成与clase不一致就可以绕过,可以用一个小技巧,把bak下载到本地的时候,自己序列化输出序列值进行base64编码,然后自己在解码,这样就回显不会丢掉\x00,然后在修改属性数量,在url编码。。。。 $select = new ctf('admin','tac flag.php'); echo base64_encode(serialize(@$sel

回复 0

0xff0000 3年前

反序列化 protected 属性的 * 旁边有 \x00 字节,URL编码的时候注意有没有变成空格%20,应该是%00才对

回复 0

196082 4年前

tac flag.php为NULL

回复 0
kaibaking 4年前

你的序列化字符长度要对应cmd命令的长度才不会为null

回复 0

lm459532915 4年前

wakeup的绕过

回复 0

17673426864 4年前

老是不对,快炸了

回复 0

17673426864 4年前

大佬,可以多给点提示吗?

回复 0

jsmaster 4年前

日狗了,反序列化中的privated和protected的东西弄了一个多小时。吐了。

回复 3

WriteUp

image
小赵同学

3 金币

评分(3)

解题动态

smtall 攻破了该题 1天前
LostDawn 攻破了该题 1天前
yy56 攻破了该题 2天前
ZZZZZZYx 攻破了该题 4天前
The-Beacon 攻破了该题 4天前
liuweiak007 攻破了该题 5天前
小坑西1 攻破了该题 5天前
Lidisheng2027 攻破了该题 7天前
NNuuNN 攻破了该题 7天前
2424291112 攻破了该题 7天前
Subuloy 攻破了该题 8天前
yiwuxiaobawang 攻破了该题 8天前
soulchild 攻破了该题 10天前
yangbing8555 攻破了该题 10天前
Cyberrui 攻破了该题 12天前
13567024312 攻破了该题 12天前
卡卡罗特M 攻破了该题 14天前
admin1322 攻破了该题 14天前
JJJleo 攻破了该题 14天前
烛火 攻破了该题 15天前
问题反馈