在CentOS 7安装配置CodeQL与运行QL扫描

1. 引言

本文讲解CodeQL在CentOS 7下的环境配置,以及运行CodeQL-CLI扫描django源码的过程。

2. 环境

  1. 为CentOS7安装配置JDK-11

    wget https://mirrors.huaweicloud.com/java/jdk/11.0.2+9/jdk-11.0.2_linux-x64_bin.tar.gz
    sudo tar -zxvf jdk-11.0.2_linux-x64_bin.tar.gz -C /usr/local/
    sudo ln -s /usr/local/jdk-11.0.2 /usr/local/jdk11
    echo 'export JAVA_HOME=/usr/local/jdk11' >> ~/.bashrc
    echo 'export PATH=JAVA_HOME/bin:PATH' >> ~/.bashrc
    source ~/.bashrc

配置成功后可以看到:

复制代码
java --version
java 11.0.2 2019-01-15 LTS
Java(TM) SE Runtime Environment 18.9 (build 11.0.2+9-LTS)
Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.2+9-LTS, mixed mode)
  1. 下载安装CodeQL-CLI

下面是下载安装CodeQL-CLI的过程。

复制代码
wget -c  https://github.com/github/codeql-cli-binaries/releases/download/v2.23.8/codeql-linux64.zip
unzip codeql-linux64.zip
echo 'export PATH="$PATH:$HOME/code/codeql"' >> ~/.bashrc
source ~/.bashrc

wget下载不稳定时,-c参数可以做到断点续传。

复制代码
$ codeql version
CodeQL command-line toolchain release 2.23.8.
Copyright (C) 2019-2025 GitHub, Inc.
  1. 下载安装CodeQL-CLI的Pack依赖

    克隆官方 CodeQL 仓库(包含 C/C++、Python 等语言的标准库和查询 Pack)

    git clone https://github.com/github/codeql.git codeql-repo

    进入仓库并拉取最新 Pack

    cd codeql-repo
    git checkout main
    git pull
    cd ..

    安装 C/C++ Pack 依赖(自动下载缺失依赖)

    codeql pack install codeql-repo/cpp/ql/src # 核心分析库

    安装 Python Pack 依赖

    codeql pack install codeql-repo/python/ql/src

最终输入如下命令,运行正常(参考1)则说明配置成功。

复制代码
codeql resolve packs

3. 运行

  1. 下载django源码

    git clone https://github.com/django/django.git

  2. 为django源码创建codeql数据库(参考2)

    codeql database create codeql-django-db --language=python --source-root=django

  3. 运行codeql扫描代码(参考3)

    codeql database analyze codeql-django-db codeql-repo/python/ql/src/Classes/UselessClass.ql --format=sarif-latest --output=log.sarif

4. 参考

  1. https://docs.github.com/en/code-security/codeql-cli/getting-started-with-the-codeql-cli/setting-up-the-codeql-cli
  2. https://docs.github.com/en/code-security/codeql-cli/getting-started-with-the-codeql-cli/preparing-your-code-for-codeql-analysis
  3. https://docs.github.com/en/code-security/codeql-cli/getting-started-with-the-codeql-cli/analyzing-your-code-with-codeql-queries
相关推荐
Leinwin3 小时前
OpenClaw 多 Agent 协作框架的并发限制与企业化规避方案痛点直击
java·运维·数据库
2401_865382503 小时前
信息化项目运维与运营的区别
运维·运营·信息化项目·政务信息化
漠北的哈士奇3 小时前
VMware Workstation导入ova文件时出现闪退但是没有报错信息
运维·vmware·虚拟机·闪退·ova
如意.7594 小时前
【Linux开发工具实战】Git、GDB与CGDB从入门到精通
linux·运维·git
Thera7774 小时前
C++ 高性能时间轮定时器:从单例设计到 Linux timerfd 深度优化
linux·开发语言·c++
运维小欣4 小时前
智能体选型实战指南
运维·人工智能
yy55274 小时前
Nginx 性能优化与监控
运维·nginx·性能优化
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ5 小时前
Linux 查询某进程文件所在路径 命令
linux·运维·服务器
05大叔7 小时前
网络基础知识 域名,JSON格式,AI基础
运维·服务器·网络
安当加密7 小时前
无需改 PAM!轻量级 RADIUS + ASP身份认证系统 实现 Linux 登录双因子认证
linux·运维·服务器