CodeQL使用流程
阅读原文时间:2023年07月09日阅读:2

前言

好久没用CodeQL了,看了自己之前写的文章发现竟然没有做过相关记录

然后就不知道怎么用了hhh

使用流程

我们拿到一套源码,首先需要使用CodeQL生成数据库

执行命令:

codeql database create <database> --language=<language-identifier>

参数说明:

<database>:创建数据库的路径,目录会在执行命令的时候被创建

--language: 指定数据库语言,输入标识符。当和--db-cluster一起使用时,可以指定多个,用','分隔,也可以进行多次指定。

--db-cluster:为多种语言创建数据库

--command:创建一个或多个编译语言数据库的时候使用。python和JavaScript/TypeScript不需要该参数,如果编译语言不带该参数,codeql会自动检测并编译

--no-run-unnecessary-builds:为多语言创建数据库,且包括编译和非编译语言时,可以利用 --no-run-unnecessary-builds来帮助非编译语言跳过command选项

更多参数说明

CodeQL支持以下语言

语言

标识符

C/C++

cpp

C#

csharp

GO

go

Java

java

JavaScript/TypeScript

javascript

Python

python

Ruby

ruby

案例:

codeql database create xxx-database  --language="java"  --command="mvn clean install --file pom.xml" --source-root=文件目录

成功之后

然后在当前目录下会生成一个名为“xxx-database”的文件夹

这里使用‘starter workspace’,也就是git仓库

  1. 下载starter

    git clone --recursive https://github.com/github/vscode-codeql-starter/

    或者

    git clone https://github.com/github/vscode-codeql-starter/

    项目下载完成后,进入项目目录

    git submodule update --init

    git submodule update --remote

    确保包含需要的子模块

    截图使用的是第一种方法

子模块需要定期更新

  1. 在VS Code中打开starter workspace

注意:

starter子模块中包括C/C++, C#, Java, JavaScript, Python, Ruby以及GO的规则,在vscode-codeql-starter\ql下

CodeQL暂时无法扫描php代码

我们生成的数据库为文件夹,那我们就选择 "From a folder"

点开项目文件,我们可以看见ql下有很多规则

因为示例源码为java语言,我们选择java下的规则文件夹

右键选择"CodeQL:RunQueries in Selected Files"

里面有81个CWE规则

点击左侧的一条规则,可以看到对应规则运行的结果在右侧

手机扫一扫

移动阅读更方便

阿里云服务器
腾讯云服务器
七牛云服务器

你可能感兴趣的文章