CVE-2021-3115——Golang Windows版本 RCE漏洞

安全 漏洞
研究人员在Golang Windows版本中发现一个RCE漏洞。

 

1月,谷歌工程师修复了Go语言(Golang)中的一个远程代码执行漏洞。该漏洞CVE编号为CVE-2021-3115,漏洞主要影响使用go get命令的Windows Go用户。

非可信目录路径查找RCE

该漏洞是由日本安全研究人员RyotaK发现的,属于命令注入漏洞。漏洞产生的根本原因是用户运行go get命令来提取库时编译过程的工作原理造成的。

在Windows 系统中,用户或程序运行的操作系统shell命令会引发shell 在当前目录中搜索与该命令有关的二进制文件或可执行文件,然后在系统PATH变量中指定一个目录列表。

比如,如果在Windows 命令窗口输入netstat,Windows就会在当前目录中搜索netstat.exe、netstat.bat或其他netstat.*可执行文件,这些搜索到的文件会优先执行。


测试Windows PATH查找

如果当前目录中不存在netstat 相关的可执行文件,那么Windows shell就会查找netstat 系统工具,该系统工具位于 Windows %PATH% 变量中。

由于与该行为相关的安全风险,Windows PowerShell和Unix shell在执行命令时都已经放弃了该默认行为,开始优先处理非可信当前目录上的%PATH% 变量位置。

也就是说,在PowerShell 中运行netstat 会启动netstat系统工具,而不是本地的netstat.bat,因为PoweShell 会优先在%PATH% 目录中搜索包含该名字的二进制文件。

为了保持一致性,Golang 二进制文件在Unix 系统中效仿了Unix 规则,在Windows 系统中效仿了Windows 规则。也就是说,运行下面的命令在Unix系统和Windows 系统中会产生不同的行为:

  1. out, err := exec.Command("go""version").CombinedOutput() 

在Windows 系统中,本地的Go二进制文件优先级高,而Unix 系统中会首先搜索$PATH 变量来确认其可信位置中是否存在go 二进制文件。

这种优先本地、非可信目录的方法也在Go helper和编译器中实现了,比如为调用C语言代码生成Go包的工具——cgo。

Cgo在Windows系统中编译C代码时,Golang可执行文件首先会在非可信的本地目录中搜索GCC编译器。Cgo运行的go命令会包含包资源。因此,攻击者可以利用cgo来启动恶意的gcc.exe程序。

虽然该行为可能是由多个编译器、库等造成的,但是Golang Project决定修复该漏洞,并已经发布了补丁。

总结

研究人员RyotaK 称该漏洞的发现是受CVE-2020-27955漏洞启发,CVE-2020-27955是Git LFS中的命令注入漏洞,该漏洞是由于不安全的文件执行引发的Git LFS远程代码执行漏洞。

研究人员建议用户升级到最新的Go v1.14.14版本来避免该漏洞的利用。

本文翻译自:https://www.bleepingcomputer.com/news/security/google-fixes-severe-golang-windows-rce-vulnerability/如若转载,请注明原文地址。

 

责任编辑:姜华 来源: 嘶吼网
相关推荐

2021-09-10 11:41:20

漏洞Windows 微软

2021-07-21 10:04:02

安全漏洞Windows

2021-05-27 05:34:47

漏洞网络安全网络攻击

2021-03-16 10:52:56

Chrome浏览器漏洞

2022-02-10 11:52:10

Windows漏洞Windows 10

2021-10-29 11:52:16

谷歌漏洞TPM

2021-10-06 13:54:12

漏洞PoC攻击

2021-11-08 11:52:17

漏洞LinuxLinux TIPC

2021-09-23 15:20:18

微软漏洞代码

2021-01-30 18:31:00

sudo缓存溢出漏洞

2020-12-11 11:18:43

MiTMKubernetes漏洞

2020-10-05 21:41:58

漏洞网络安全网络攻击

2013-04-22 15:47:35

漏洞CVE-2013-00IE

2024-01-23 11:45:27

2022-03-31 11:55:50

漏洞VoIP应用RCE漏洞

2021-09-08 11:45:50

OpenSSL RCE漏洞Synology产品

2021-11-26 09:55:09

微软漏洞补丁

2020-10-22 11:24:53

修复漏洞

2021-11-01 11:59:56

Windows 操作系统漏洞

2022-06-14 09:00:21

漏洞补丁
点赞
收藏

51CTO技术栈公众号