旧版本的 golang.org/x/net/html 存在漏洞。哎呀!更好地升级软件包。两年前,我们使用govendor建立了我们的Shopify集成项目;因此,让我们使用GoVendor进行升级:
ip-192-168-3-40:Shopify-Gateway username$ git diff
ip-192-168-3-40:Shopify-Gateway username$ govendor fetch golang.org/x/net/html
ip-192-168-3-40:Shopify-Gateway username$ git diff
ip-192-168-3-40:Shopify-Gateway username$
Govendor什么都没做!这是fetch
之后的vendor.json
文件:
{
"checksumSHA1": "vqc3a+oTUGX8PmD0TS+qQ7gmN8I=",
"path": "golang.org/x/net/html",
"revision": "d997483c6db05184c79c182674d01f1e7b7553ae",
"revisionTime": "2017-05-30T13:01:13Z"
},
这是一个相当古老的修订版,肯定比2018年9月25日的漏洞修复程序要早。Govendor是一个较旧的软件包,似乎不再维护。我必须更换govendor吗?有自然替代品吗?还是我做错了什么阻止我更新我的软件包?
版本信息:
ip-192-168-3-40:Shopify-Gateway username$ govendor --version v1.0.9
ip-192-168-3-40:Shopify-Gateway username$ go version
go version go1.13.1 darwin/amd64
编辑:许多人建议使用go模块。我们不能使用它们!我们依赖于不受版本控制的依赖项,当我们尝试将包升级到 go 模块时,此依赖项会下降到较低版本,从而引入数据库安全漏洞。我需要能够就地更新软件包,因为它们是由govendor安装的。
我还尝试安装我要使用的govendor软件包的特定版本号:
ip-192-168-3-40:Shopify-Gateway username$ govendor fetch golang.org/x/net/html@d26f9f9a57f3fab6a695bec0d84433c2c50f8bbf
ip-192-168-3-40:Shopify-Gateway username$ git diff
ip-192-168-3-40:Shopify-Gateway username$
为什么govendor不更新我的软件包?
您必须迁移到go modules
。 首先,创建一个新模块。通过这些简单的步骤,您将能够初始化模块并创建go.mod
文件 [https://stackoverflow.com/a/57944766/9361998]。
比你必须输入:
go mod init YOUR_REPOSITORY_NAME
go clean
go mod download # wait until dependencies are downloaded
go build #be sure that the code compile
go mod tidy #prune unnecessary dependencies
go get -u ./... #update dependencies
请注意,使用最新命令将 dep 更新到最新的次要修补程序,请务必使用最新的 MAJOR 版本更改go.mod
文件
编辑
另一种方法是使用go get -v -u github.com/repository_name/module_name
在GOPATH
中下载模块。这样,该模块将下载到您的GOPATH
中。