首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在反序列化之前验证对象流的内容?

如何在反序列化之前验证对象流的内容?
EN

Stack Overflow用户
提问于 2017-01-08 14:36:29
回答 1查看 2K关注 0票数 0

我们正在尝试实现安全的应用程序框架,作为其中的一部分,为了在反序列化之前避免拒绝服务攻击,我们希望知道有多少对象正在被反序列化,并在超过阈值时中止反序列化。

为了满足上述需求,我搜索了一些论坛,了解到有一些实现java序列化的方法,即

代码语言:javascript
复制
resolveClass(ObjectStreamClass desc)
resolveObject(Object obj)

但是我没有得到任何关于这两个methods.Can的文档或示例,有人给我发了帖子,或者给出了一些关于这些方法/定制反序列化的简要信息

EN

回答 1

Stack Overflow用户

发布于 2017-01-08 14:50:55

您正在寻找的两种方法都在java.io.ObjectInputStream类(link)中。IBM有一篇很好的文章解释了前瞻Java反序列化here。基本上,您可以子类化java.io.ObjectInputStream并覆盖resolveClass()方法,以验证要反序列化的类是否为您所期望的类,如下所示:

代码语言:javascript
复制
public class LookAheadObjectInputStream extends ObjectInputStream {

    public LookAheadObjectInputStream(InputStream inputStream)
            throws IOException {
        super(inputStream);
    }

    /**
     * Only deserialize instances of our expected Bicycle class
     */
    @Override
    protected Class<?> resolveClass(ObjectStreamClass desc) throws IOException,
            ClassNotFoundException {
        if (!desc.getName().equals(Bicycle.class.getName())) {
            throw new InvalidClassException(
                    "Unauthorized deserialization attempt",
                    desc.getName());
        }
        return super.resolveClass(desc);
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41530173

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档