加入收藏 | 设为首页 | 会员中心 | 我要投稿 济源站长网 (https://www.0391zz.cn/)- 数据工具、数据仓库、行业智能、CDN、运营!
当前位置: 首页 > 服务器 > 安全 > 正文

如何使用GoKart对Go代码进行静态安全分析

发布时间:2022-06-27 10:35:01 所属栏目:安全 来源:互联网
导读:关于GoKart GoKart是一款针对Go代码安全的静态分析工具,该工具能够从Go源代码中查找使用了SSA(单一静态分配)形式的代码漏洞。GoKart能够跟踪变量和函数参数的来源,以确定输入源是否安全,与其他Go安全扫描程序相比,GoKart能够有效减少误报的数量。例如,
  关于GoKart
  GoKart是一款针对Go代码安全的静态分析工具,该工具能够从Go源代码中查找使用了SSA(单一静态分配)形式的代码漏洞。GoKart能够跟踪变量和函数参数的来源,以确定输入源是否安全,与其他Go安全扫描程序相比,GoKart能够有效减少误报的数量。例如,与变量连接的SQL查询传统上可能标记为SQL注入,然而,GoKart可以确定变量实际上是常量还是类似常量的参数,在这种情况下GoKart不会报出漏洞。
 
  工具安装
  我们可以使用下列方式之一来安装GoKart。
 
  (1) go install安装
 
  广大研究人员可以使用下列命令安装GoKart:
 
  复制
  $ go install github.com/praetorian-inc/gokart@latest
  1.
  (2) 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
  1.
  2.
  3.
  4.
  5.
  6.
  7.
  8.
  9.
  然后,提取已下载好的文档:
 
  复制
  $ tar -xvf gokart_${VERSION}_${ARCH}.tar.gz
  1.
  最后,将GoKart代码移动至我们的运行路径中:
 
  复制
  $ mv ./gokart /usr/local/bin/
  1.
  (3) 源码安装
 
  首先,我们需要使用下列命令将该项目源码克隆至本地:
 
  复制
  $ git clone https://github.com/praetorian-inc/gokart.git
  1.
  然后切换至项目根目录,并构建源码:
 
  复制
  $ cd gokart
   
  $ go build
  1.
  2.
  3.
  最后,将GoKart代码移动至我们的运行路径中:
 
  复制
  $ mv ./gokart /usr/local/bin
  1.
  Docker支持
  构建Docker镜像:
 
  复制
  docker build -t gokart .
  1.
  运行容器,并执行本地扫描(本地扫描目录需要加载至容器镜像中):
 
  复制
  docker run -v /path/to/scan-dir:/scan-dir gokart scan /scan-dir
  1.
  运行容器,并执行远程扫描(指定私钥以作认证,并加载至容器中):
 
  复制
  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
  1.
  2.
  3.
  4.
  5.
  工具使用
  针对当前目录中的Go模块运行GoKart:
 
  复制
  # running without a directory specified defaults to '.'
   
  gokart scan <flags>
  1.
  2.
  3.
  扫描不同目录中的Go模块:
 
  复制
  gokart scan <directory> <flags>
  1.
  查看帮助信息:
 
  复制
  gokart help
  1.
  项目地址
  GoKart:【GitHub传送门】

(编辑:济源站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读