freeBuf
主站

分类

漏洞 工具 极客 Web安全 系统安全 网络安全 无线安全 设备/客户端安全 数据安全 安全管理 企业安全 工控安全

特色

头条 人物志 活动 视频 观点 招聘 报告 资讯 区块链安全 标准与合规 容器安全 公开课

官方公众号企业安全新浪微博

FreeBuf.COM网络安全行业门户,每日发布专业的安全资讯、技术剖析。

FreeBuf+小程序

FreeBuf+小程序

如何使用GoKart对Go代码进行静态安全分析
2021-10-02 12:45:39

关于GoKart

GoKart是一款针对Go代码安全的静态分析工具,该工具能够从Go源代码中查找使用了SSA(单一静态分配)形式的代码漏洞。GoKart能够跟踪变量和函数参数的来源,以确定输入源是否安全,与其他Go安全扫描程序相比,GoKart能够有效减少误报的数量。例如,与变量连接的SQL查询传统上可能标记为SQL注入,然而,GoKart可以确定变量实际上是常量还是类似常量的参数,在这种情况下GoKart不会报出漏洞。

工具安装

我们可以使用下列方式之一来安装GoKart。

go install安装

广大研究人员可以使用下列命令安装GoKart:

$ go install github.com/praetorian-inc/gokart@latest

Release安装

首先,我们需要访问该项目的【Releases页面】,并下载GoKart源码至本地系统。

接下来,我们可以下载checksums.txt文件来验证下载包的完整性:

# Check the checksum of the downloaded archive

$ shasum -a 256 gokart_${VERSION}_${ARCH}.tar.gz

b05c4d7895be260aa16336f29249c50b84897dab90e1221c9e96af9233751f22  gokart_${VERSION}_${ARCH}.tar.gz

$ cat gokart_${VERSION}_${ARCH}_checksums.txt | grep gokart_${VERSION}_${ARCH}.tar.gz

b05c4d7895be260aa16336f29249c50b84897dab90e1221c9e96af9233751f22  gokart_${VERSION}_${ARCH}.tar.gz

然后,提取已下载好的文档:

$ tar -xvf gokart_${VERSION}_${ARCH}.tar.gz

最后,将GoKart代码移动至我们的运行路径中:

$ mv ./gokart /usr/local/bin/

源码安装

首先,我们需要使用下列命令将该项目源码克隆至本地:

$ git clone https://github.com/praetorian-inc/gokart.git

然后切换至项目根目录,并构建源码:

$ cd gokart

$ go build

最后,将GoKart代码移动至我们的运行路径中:

$ mv ./gokart /usr/local/bin

Docker支持

构建Docker镜像:

docker build -t gokart .

运行容器,并执行本地扫描(本地扫描目录需要加载至容器镜像中):

docker run -v /path/to/scan-dir:/scan-dir gokart scan /scan-dir

运行容器,并执行远程扫描(指定私钥以作认证,并加载至容器中):

docker run gokart scan -r https://github.com/praetorian-inc/gokart
 
# specifying a private key for private repository ssh authentication

docker run -v /path/to/key-dir/:/key-dir gokart scan -r git@github.com:praetorian-inc/gokart.git -k /key-dir/ssh_key

工具使用

针对当前目录中的Go模块运行GoKart:

# running without a directory specified defaults to '.'

gokart scan <flags>

扫描不同目录中的Go模块:

gokart scan <directory> <flags>

查看帮助信息:

gokart help

项目地址

GoKart:GitHub传送门

参考资料

https://www.praetorian.com/blog/introducing-gokart/

https://github.com/praetorian-inc/gokart/releases

https://github.com/Contrast-Security-OSS/go-test-bench

# 静态分析 # 代码安全 # Go安全
本文为 独立观点,未经允许不得转载,授权请联系FreeBuf客服小蜜蜂,微信:freebee2022
被以下专辑收录,发现更多精彩内容
+ 收入我的专辑
+ 加入我的收藏
相关推荐
  • 0 文章数
  • 0 关注者
文章目录