使用具有已知漏洞的组件,这种安全漏洞普遍存在,基于组件开发的模式使得多数开发团队根本不了解其应用或API中使用的组件,更谈不上及时更新这些组件了。
下面就分别以.NET和Java各分享一个案例。

.NET 案例:XmlSerializer反序列化漏洞

案例描述

在.NET框架中,XmlSerializer类是一个常用的工具,用于将高度结构化的XML数据映射为.NET对象。然而,如果开发人员不当地使用XmlSerializer类来反序列化外部输入的XML数据,就可能触发反序列化漏洞,导致任意代码执行等安全问题。

具体案例

漏洞类型:XmlSerializer反序列化漏洞
影响:攻击者可以通过构造恶意的XML数据,利用该漏洞执行任意代码。
示例:在.NET应用程序中,如果开发人员使用
XmlSerializer.Deserialize方法反序列化来自不可信源的XML数据,而没有进行适当的验证和过滤,就可能受到攻击。例如,在DotNetNuke平台中,就曾发现过由于不当使用XmlSerializer而导致的任意代码执行漏洞(CVE-2017-9822)。

防护措施

  1. 对所有外部输入的XML数据进行严格的验证和过滤。
  2. 使用安全的反序列化方法,如.NET Core中的System.Text.Json或第三方库。
  3. 定期更新.NET框架和所有依赖的库,以修复已知的安全漏洞。

Java 案例:fastjson反序列化漏洞

案例描述

fastjson是阿里巴巴开发的一个高性能的JSON库,广泛用于Java应用程序中。然而,fastjson在反序列化不可信数据时存在远程代码执行的安全漏洞。

具体案例

漏洞类型:fastjson反序列化漏洞
影响:攻击者可以通过发送恶意构造的JSON数据,利用该漏洞执行任意代码,从而完全控制受影响的系统。
示例:在Java应用程序中,如果开发人员使用fastjson来反序列化来自外部源的JSON数据,并且没有正确配置或更新fastjson库,就可能受到攻击。恶意用户可以通过在JSON数据中包含特定的@type字段来触发漏洞,并执行恶意代码。

防护措施

  1. 升级fastjson到最新版本,以包含最新的安全修复。
  2. 禁止在反序列化过程中使用@type字段,或者在必要时进行严格的验证和过滤。
  3. 考虑使用其他安全的JSON库,如Jackson或Gson。
  4. 对所有外部输入的JSON数据进行严格的验证和过滤。
这两个案例都强调了在使用具有已知漏洞的组件时可能面临的安全风险,并提供了相应的防护措施。在实际开发中,开发人员应该密切关注所使用的组件的安全性和更新情况,及时采取必要的措施来保护应用程序的安全。
 
另外,我最近开发并开源了一个支持免费申请通配符SSL证书的平台:华迅FreeCert,解决了每隔一段时间就要重新申请和部署证书(因为传统的云厂商提供的免费证书一般只有三个月有效期),不支持免费申请通配符证书这两大痛点,欢迎大家注册使用并提供宝贵意见,谢谢!

详解Web应用安全系列(7)使用具有已知漏洞的组件的更多相关文章

  1. 框架基础学习之--详解web+maven+spring+mybatis+struts框架文件夹作用

    详解web+maven+spring+mybatis+struts框架文件夹作用 1.程序名 2.Mybatis,mybatis是数据持久层,就是和对象类有关系的东西 3.存放java文件,xml,p ...

  2. ps切图抠图详解-web前端(转)

    网页设计在技术层面上,第一步是美工做出网页效果图,第二步就是网页前端进行网页切图.网页切图工具常用的有fireworks.PS,这里使用PS进行网页切图. 我们通过设计稿,得到我们想要的产出物(如.p ...

  3. 详解web容器 - Jetty与Tomcat孰强孰弱

    Jetty 基本架构 Jetty目前的是一个比较被看好的 Servlet 引擎,它的架构比较简单,也是一个可扩展性和非常灵活的应用服务器.它有一个基本数据模型,这个数据模型就是 Handler(处理器 ...

  4. day08:软件系统的体系结构&Tomcat详解&Web应用&http协议

        day08 软件系统体系结构     常见软件系统体系结构B/S.C/S 1.1 C/S C/S结构即客户端/服务器(Client/Server),例如QQ: 需要编写服务器端程序,以及客户端 ...

  5. 详解web.xml中元素的加载顺序

    一.背景 最近在项目中遇到了启动时出现加载service注解注入失败的问题,后来经过不懈努力发现了是因为web.xml配置文件中的元素加载顺序导致的,那么就抽空研究了以下tomcat在启动时web.x ...

  6. web应用配置文件详解(web.xml)

    转载链接地址:http://blog.csdn.net/guihaijinfen/article/details/8363839 <?xml version="1.0" en ...

  7. 详解 Web基本概念

    作为本专栏的第一篇博文,本人将带领同学们初步了解什么是Web,以及有关Web学习的一些基本知识点 那么,话不多说,开始主题的讲解吧: 首先,本人来解释下什么是Web: 概念: 使用浏览器进行访问的应用 ...

  8. 【转】详解web.xml中元素的加载顺序

    顺序为: context-param --> listeners --> filters --> servlets(如DispatcherServlet等) 详见<https: ...

  9. 详解C# 网络编程系列:实现类似QQ的即时通信程序

    https://www.jb51.net/article/101289.htm 引言: 前面专题中介绍了UDP.TCP和P2P编程,并且通过一些小的示例来让大家更好的理解它们的工作原理以及怎样.Net ...

  10. 详解Web请求中的DNS域名解析

    当我们打开浏览器,输入一个URL去请求我们需要的资源,但是URL是需要解析成对应的IP地址才能与远程主机建立连接,如何将URL解析成IP就是DNS的工作范畴,即使作为开发人员,这个过程我们也感觉不到, ...

随机推荐

  1. Centos 密码过期问题 password has expired

    1.这个主要是由/etc/login.defs参数文件中的一些参数控制的的.它主要用于用户账号限制PASS_MAX_DAYS 60     #密码最大有效期,此处参数PASS_MAX_DAYS为60, ...

  2. 密码学—Kasiski测试法Python程序

    Kasiski Kasiski是辅助破解Vigenere的前提工作,Kasiski是猜测加密者使用Vigenere密码体系的密钥的长度,Kasiski只是猜测长度而已,所以说是辅助破解Vigenere ...

  3. pageoffice6 版本在线打开word 文件,实现多用户同时编辑

    总体来说,各种Web系统中的Word文档在线处理大体可以分为以下四种流转处理方式: A用户编辑完,流转给B用户修改,再流转给C用户修改,直到最后.每个用户都是针对全文修改的,如果需要在这一篇文档中能区 ...

  4. go高并发之路——go语言如何解决并发问题

    一.选择GO的原因 作为一个后端开发,日常工作中接触最多的两门语言就是PHP和GO了.无可否认,PHP确实是最好的语言(手动狗头哈哈),写起来真的很舒爽,没有任何心智负担,字符串和整型压根就不用区分, ...

  5. tkinter小例子

    from tkinter import * def on_click(): label['text'] = text.get() root = Tk(className='hello') root.m ...

  6. Linux之top命令下的交互快捷键

    快捷键: 数字1----查看服务器的cpu逻辑数 M -根据驻留内存大小进行排序 P -根据CPU使用百分比大小进行排序 T -根据时间/累计时间进行排序 c -切换显示命令名称和完整命令行 t -切 ...

  7. CSS——float浮动属性

    流动布局 流动模型(Flow),即文档流,浏览器打开HTML网页时,从上往下,从左往右,逐一加载. 在正常情况下,HTML元素都会根据文档流来分布网页内容的. 文档流有2大特征: ① 块状元素会随着浏 ...

  8. kubernetes 二次开发-认证,鉴权(1)

    基于webhook的认证 授权过程 认证授权服务需要满足如下kubernetes的规范 kubernetes api-server组件发送 http post 请求 url:https://authn ...

  9. vsftp配置使用

    vsftp简介: VSFTP是一个基于GPL发布的类Unix系统上使用的FTP服务器软件,它的全称是Very Secure FTP 从此名称可以看出来,编制者的初衷是代码的安全. 安全性是编写VSFT ...

  10. tar解压报错——Not found in archive tar: Exiting with failure status due to previous errors

    tar解压报错--Not found in archive [root@master software]# tar -xzf scala-2.11.8.tgz /usr/local/ tar: /us ...