第一句子大全,网罗天下好句子,好文章尽在本站!

IP地址数据解析漏洞 多语言语言net类库受影响

时间:2013-05-03

本周在DEF CON大会上,由多名安全研究人员披露十进制和八进制混合IP地址解析漏洞,多种语言的受影响,包括Go和Rust的官方类库net。以及Python的标准库ip

友情提示:本文共有 1215 个字,阅读大概需要 3 分钟。

本周在DEF CON大会上,由多名安全研究人员披露十进制和八进制混合IP地址解析漏洞,多种语言的受影响,包括Go和Rust的官方类库net。以及Python的标准库ipaddress。

概述

Go和 Rust语言中常用的net库,受到混合格式IP 地址验证漏洞的影响。该漏洞源于库中对IP地址处理时候将八进制-十进制)格式混合格式的八进制的数据当作十进制有关。

所有使用这次基础库的应用程序可能会受到不确定的服务器端请求伪造(SSRF) 和远程文件包含(RFI) 漏洞的攻击。

因为该基础库被广使用,所以大量的Go,Rust网络应用都受到影响。

另外,Python 标准库ipaddress也受漏洞影响。

漏洞原理

漏洞CVE编号为CVE-2021-29922(Rust库)和 CVE-2021-29923(Golang库),主要在其同名类库net处理混合格式的IP地址,或者更具体地说,当十进制IPv4 地址包含数据以0开始时。

众所周知,IP地址可以用多种格式表示,包括十六进制和整数,尽管最常见的IPv4地址以十进制格式表示。

比如8.8.8.8

该地址可以用八进制格式表示为 0010.0010.0010.0010。

我们日常最常用的一个本地IP地址(回环地址,localhost)为127.0.0.1。 假如对其第一部分IP地址添加一个0,则0127.0.0.1 会被解析为啥呢?

我们在浏览器中输入这个地址。在火狐浏览器的地址栏中输入0127.0.0.1,浏览器将其自动转化为八进制格式 。

其他浏览器也是如此,比如谷歌Chrome:

根据IETF草案,如果前缀为“0”,则 IPv4 地址的部分可以解释为八进制。但是,在net库中,任何前置零的地址都被简单地剥离和丢弃。

在Golang和Rust的net模块中将IPv4地址的八位字节都被简单视为十进制。 因此,如果开发人员使用net来验证IP地址是否属于某个范围(例如,根据访问控制列表 (ACL) 解析IP列表),对于基于八进制的IPv4地址表示,结果可能会完全错误。

这样可能会导致应用程序中出现不确定的服务器端请求伪造 (SSRF)和远程文件包含(RFI)漏洞。

漏洞影响

由于net库在Golang和Rust语言中均为核心库,被大量应用所依赖,通过在Github上简单搜索,仅golang中依赖该库的代码文件超超过49w。

而且Go和Rust不是唯一受该漏洞影响的语言,还有Python语言的ipaddress 库 (CVE-2021-29921)、 netmask库 (CVE-2021-28918、CVE-2021-29418) 和等类似的库也受影响。

该系列漏洞大多都被评为有高或严重的严重性。

漏洞解决

目前 Golang 的 net 模块将补丁将在Golang 1.17 版中发布。

对于 Rust net里,也已经有一个修复程序已经合并:

请使用这些类库的同学,关注官方漏洞发布及时更新版本。

本文如果对你有帮助,请点赞收藏《IP地址数据解析漏洞 多语言语言net类库受影响》,同时在此感谢原作者。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。
相关阅读
NET开发-在SQL Server中使用不带条件和带条件的SQL语句更新数据

NET开发-在SQL Server中使用不带条件和带条件的SQL语句更新数据

....NET开发的应用程序中,如果您需要修改密码,更改收货地址等,这些需求在SQL Server数据库中都属于更新数据操作,使用新的数据替换掉原来的数据。我们都知道,数据是存储在SQL Server数据库表中的,在不更新数据的情况下,一...

2023-12-16 #经典句子

在ASP.NET Web应用程序中使用C#循环语句实现基本的循环工作

在ASP.NET Web应用程序中使用C#循环语句实现基本的循环工作

...表驱动进行的。而在计算机中,也存在循环,例如:要从数据库中将所有的学生信息全部读出来。可以使用循环,让计算机去一个一个的帮我们拿出来。在C#中可以使用的循环语句有:while、do…while、for、foreach这4个。2.While循环...

2017-12-19 #经典句子

网站漏洞检测 之后台php语句拼接webshell漏洞

网站漏洞检测 之后台php语句拼接webshell漏洞

...就可以一直保持后台的登录状态。我们直接去访问后台的地址,就可以直接登录进去。截图如下:有了网站后台管理员权限,一般都会想上传webshell,那么后台我们在代码的安全审计中发现有一处漏洞,可以插入php语句并拼接导...

2023-06-14 #经典句子

一个合格的.NET程序员 要会使用C#异常处理语句来提升用户体验

一个合格的.NET程序员 要会使用C#异常处理语句来提升用户体验

...执行,用来保障一些操作必须被执行,如释放资源、关闭数据库连接等,主要是为异常处理后事的,因为一旦出现异常,catch后面的代码将不再执行,但是finally中的后置代码是肯定执行的。在图8中,不管是否发生意外,都会执...

2023-10-18 #经典句子

在.NET开发中 C#循环语句可以退出 那何时退出比较好呢?

在.NET开发中 C#循环语句可以退出 那何时退出比较好呢?

...在循环语句中使用,如for、foreach、while、do…while语句。C#语言中的break语句的含义是退出整个循环体,退出后执行后面的代码,不再继续执行循环了。使用Visual Studio 2019创建一个.NET控制台应用程序,并在Main()方法中编写如下代码...

2008-03-06 #经典句子

C语言指针

C语言指针

...瘾。说明:为了方便讲解和理解,文中配图的内存空间的地址是随便写的,在实际计算机中是要遵循地址对齐方式的。变量与指针的本质2.1 内存地址我们编写一个程序源文件之后,编译得到的二进制可执行文件存放在电脑的硬...

2023-08-13 #经典句子

SQL语句数据分析法在公立医院领导干部经济责任审计中的运用

SQL语句数据分析法在公立医院领导干部经济责任审计中的运用

...证明与本网联系,我们将及时更正、删除,谢谢。 邮箱地址:newmedia@xxcb.cn

2023-06-30 #经典句子

一句话说透英特尔史诗级漏洞

一句话说透英特尔史诗级漏洞

...利用Spectre漏洞可以突破用户间的隔离,窃取其他用户的数据。“云服务中的用户隔离是云安全的基石,Spectre漏洞突破云服务中用户隔离的能力可以对云服务产生致命的危害。”腾讯安全玄武实验室负责人于旸解释道。目前国内...

2023-06-12 #经典句子