09 | 反序列化漏洞:使用了编译型语言,为什么还是会被注入?
该思维导图由 AI 生成,仅供参考
- 深入了解
- 翻译
- 解释
- 总结
Java反序列化漏洞是一种严重的安全漏洞,可能导致黑客攻击并控制服务器。本文通过介绍Java反序列化漏洞的产生过程和攻击原理,帮助读者了解其危害和防范措施。文章首先解释了序列化和反序列化的概念,然后详细分析了一个经典的反序列化漏洞案例,以及黑客利用该漏洞进行攻击的过程。通过分析漏洞的产生和攻击原理,读者可以更深入地理解反序列化漏洞的危害性。文章还介绍了黑客利用反序列化漏洞可能进行的攻击,包括执行任意命令和发起拒绝服务攻击。最后,文章强调了防范反序列化漏洞的重要性,提醒读者关注版本更新中的漏洞修复,并加强安全防护措施。 在防范反序列化漏洞方面,文章提出了三种具体的防护方法:认证和签名、限制序列化和反序列化的类以及RASP检测。认证和签名可以通过加入签名的方式进行防护,限制序列化和反序列化的类则通过构建黑名单的方式来检测反序列化过程中调用链的异常。而RASP通过hook等方式,在关键函数的调用中增加一道规则的检测,能够在不修改代码的情况下对反序列化漏洞攻击实现拦截。最后,文章总结了反序列化漏洞的产生原理和防范方法,强调了认证和检测的重要性,并留下思考题,引导读者深入思考和学习。 通过本文的阅读,读者可以全面了解Java反序列化漏洞的危害和防范措施,从而提高对Java语言安全性的认识。
《安全攻防技能 30 讲》,新⼈⾸单¥59
全部留言(18)
- 最新
- 精选
- 小晏子用过fastjson,Fastjson 1.2.24就有反序列化漏洞,这个漏洞能让黑客在服务器上执行任何命令,如果服务器开了open api,且接受参数中有json数据,json解析引用了fastjson 1.2.24,那就有很大的安全风险,拒绝服务攻击,被删除服务器文件,服务器系统被破坏,都是完全可能的。
作者回复: 是的,fastjson已经曝出过好几次反序列化漏洞了。
2019-12-287 - darren公司安服,说禁止使用jackson、fastjson,我能用什么呢,protobuf这类会安全些吗?
作者回复: gson相对安全,protobuf这种限制了数据类型,也比较安全
2020-09-093 - alan一般说运行web服务时,不要使用root权限,这跟反序列化漏洞的风险也有关系吧?
作者回复: 应该是跟所有漏洞风险都有关系,最小权限永远都是最佳实践~
2019-12-273 - ZaneJSON反序列化可能有风险,所以大多数App的网络请求数据使用表单么?
作者回复: JSON还是现在最普遍的序列化工具吧,注意及时更新三方插件,基本还是没问题的。
2020-03-202 - 翠羽香凝老师给的示例代码,难道只有我一个人没有重现出来吗?重现的时候代码运行,报java.lang.Override missing element entrySet错误
作者回复: 报错不重要,只要成功执行命令,打开计算器了就说明成功了。
2020-04-2721 - Cy23漏洞是不是反系列化的同时执行了某个代码, 问个本课外问题,最近有台JAVA服务器,密码被破解,通过后台上传功能,上传*马图片和各种后缀页面,通过webshell获取服务器账号,访问sql2000数据库等,暂时还没想好怎么破,隐藏上传图片功能
作者回复: 这是文件上传漏洞,可以对上传文件的类型和存储的位置做限制,基本可以修复。
2019-12-2921 - goarulin请问老师,我这执行了这段代码一直报Exception in thread "main" java.lang.annotation.IncompleteAnnotationException: java.lang.Override missing element entrySet
作者回复: 报错是必然的,因为本来就是错误的输入。但不重要,只要成功执行命令就可以了。
2020-09-17 - TeresaJackson Databind漏洞、apache log4j反序列化漏洞,我只知道通过及时升级jar包版本修复漏洞。
作者回复: 大部分情况下,能够及时升级就足够了。
2020-03-23 - 有学识的兔子老师您好。像常用的渗透工具 metaexploit 里面提供的meterpreter/reverse_tcp是不是也是利用系统的反序列化的工作流程,执行一段黑客插入的恶意指令程序.
作者回复: 我理解的reverse_tcp应该是用来建立一个反弹shell的工具,跟具体的漏洞无关。
2019-12-29 - geek.flare我是做.net 开发,在编写服务之间的通讯时经常会用到序列化和反序列化,以前真没想到会有这种漏洞。请问.net有类似的RASP工具吗?
作者回复: 目前开源的RASP,我知道的只有百度的OpenRASP,不过似乎并没有支持.net。商业版本倒是会有宣称能够实现的。从原理上说,和Java的实现机制应该比较类似。
2019-12-28