首页 > 其他分享 >CodeQL基本使用

CodeQL基本使用

时间:2024-01-11 15:05:31浏览次数:23  
标签:基本 CodeQL codeql python 使用 查询 -- sql select

0x01 安装codeql

去github下载一个对应版本的codeql捆绑包。

https://github.com/github/codeql-action/releases

然后解压,这里我是解压到桌面

CodeQL基本使用_代码审计

然后用添加到环境变量中 然后在任意位置输入codeql命令,如果能有以下提示就表示安装成功

CodeQL基本使用_代码审计_02

CodeQL基本使用_CodeQL_03

然后下载vscode, 并且给vscode安装codeql扩展

CodeQL基本使用_漏洞挖掘_04

0x02 创建codeql数据库

在使用 CodeQL 分析代码之前,需要创建一个 CodeQL 数据库。

创建codeql数据库命令:

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

<database> 是创建数据库的路径 执行命令会自动创建一个文件夹

<language-identifier> 是选定的语言 比如java,python等

比如需要审计一个python程序,那么命令就可以如下 (注意这条命令需要在需要审计的源代码目录中使用,codeql默认是使用当前位置作为源文件目录)

codeql database create pythondb --language=python # 也可以用source-root指定源码路径 比如源码文件在d:/python_code codeql database create pythondb --language=python --source-root="d:/python_code"

然后准备好一份python的源代码。我这里是随便去github搜索了一份别人写好的代码

CodeQL基本使用_CodeQL_05

执行完毕后可以发现多了一个文件夹,这个就是codeql创建的数据库

CodeQL基本使用_漏洞挖掘_06

0x03 codeql使用

打开vscode,打开源码文件夹

CodeQL基本使用_CodeQL_07

切换到codeql插件然后选择刚刚codeql创建的数据库文件夹

CodeQL基本使用_代码审计_08

成功之后点击queries选项里面的蓝色字体,可以快速的创建一个ql查询文件。

CodeQL基本使用_代码审计_09

选择对应的语法然后回车

CodeQL基本使用_CodeQL_10

成功如下

CodeQL基本使用_代码审计_11

0x04 ql语法简介

分析一下自动生成的脚本文件是什么意思

import python // 用于引入Python语言的元数据和查询库 比如import java就是引用java的元数据和查询库 from File f // 引入文件(File)元数据的语法 select f, "Hello, world!" // (其实这是一条语句) select和sql中的select类似查询一个具体值

帮助网安学习,全套资料S信免费领取:

① 网安学习成长路径思维导图

② 60+网安经典常用工具包

③ 100+SRC分析报告

④ 150+网安攻防实战技术电子书

⑤ 最权威CISSP 认证考试指南+题库

⑥ 超1800页CTF实战技巧手册

⑦ 最新网安大厂面试题合集(含答案)

⑧ APP客户端安全检测指南(安卓+IOS)

select关键字

和sql的select类似,查询一个字符串的结果。

CodeQL基本使用_代码审计_12

from关键字

用于定义变量,格式如 from 变量类型 变量名, 如定义字符串变量str如下 (多个变量用逗号分隔)

from string str

from string str1, string str2

wher关键字

用于赋值和逻辑运算,比如where str = "abcde" 就是将str变量赋值为abcde字符串 

where str1 = "a" and str2 = "b"

注意以上语句需要配合使用不能单独使用,这里是和编程语言的语法有一些区别,更加贴近于sql语法

CodeQL基本使用_CodeQL_13

还有一些内置的类,如Function 表示一个函数类

篇幅关系,更多语法查阅官方文档:https://codeql.github.com/docs/

0x05 实际使用

比如这里是用codeql查找sql注入,个人感觉codeql更加考验对于漏洞的理解,比起其他传统的代码审计工具,codeql显得更加灵活。

codeql其实自带了很多ql脚本,这些脚本可以帮助我们去查找漏洞最简单的方式就是使用 CodeQL CLI 捆绑包中包含的标准查询。

命令格式如下

codeql database analyze <database> --format=<format> --output=<output>

//format就是指定分析过程中生成的结果文件的格式,比如csv格式等

//output就是输出的文件名

比如

CodeQL基本使用_代码审计_14

然后打开生成的result.csv文件 可以看到如下结果

CodeQL基本使用_漏洞挖掘_15

CodeQL基本使用_漏洞挖掘_16

比如查看第一个sql注入漏洞就可以打开/utils/query.py文件 然后找到12行,函数直接excute了sql语句。且中途未经过过滤。

CodeQL基本使用_代码审计_17

在vs中使用codeql可以编写语句,比如查询query函数在哪个位置

CodeQL基本使用_漏洞挖掘_18

点击鼠标就可以跳转到对应源码界面

CodeQL基本使用_代码审计_19

然后还可以查询query函数有哪些地方调用了。

import python  
 from Call call, Name name 
 where call.getFunc() = name and name.getId() = "query" select call, call.getLocation(), "使用了query函数."

CodeQL基本使用_代码审计_20

然后挑选一个函数去跟踪,发现字符串直接拼接到sql语句中。

CodeQL基本使用_代码审计_21

  

标签:基本,CodeQL,codeql,python,使用,查询,--,sql,select
From: https://blog.51cto.com/u_14601424/9199140

相关文章

  • Vite构建基本配置
    通过vite.config.js暴露出defineConfig函数实现构造,vite会读取defineConfig返回的配置对象,配置对象需要自行编写defineConfig该函数是vite工具助手函数,用来读取构建配置,其返回一个配置参数对象通过查看源码得知,vite配置有以下可选非必要内容,常用了内容一般从root到build//读......
  • 使用CentOS搭建高性能静态HTTP服务器
    在互联网应用中,静态内容是广泛存在的,例如HTML页面、图片、视频等。为了提供高效、稳定和安全的静态内容服务,我们可以使用CentOS来搭建高性能的静态HTTP服务器。1.选择合适的软件Nginx和Apache是两个流行的HTTP服务器软件。Nginx以其高效、轻量级和快速的性能而著称,特别适合于提供......
  • MySQL运维实战(3.1) MySQL官方客户端使用介绍
    作者:俊达引言MySQL是MySQL安装包默认的客户端,该客户端程序通常位于二进制安装包的bin目录中,或者通过rpm安装包安装mysql-community-client,是数据库管理系统的重要组成部分。MySQL客户端不仅仅是一个简单的软件工具,更是连接用户与数据库之间的桥梁,对于有效地使用MySQL数据库的功......
  • CodeQL基本使用
    0x01安装codeql去github下载一个对应版本的codeql捆绑包。https://github.com/github/codeql-action/releases然后解压,这里我是解压到桌面然后用添加到环境变量中然后在任意位置输入codeql命令,如果能有以下提示就表示安装成功然后下载vscode,并且给vscode安装codeql扩......
  • 网络安全应急响应的基本流程
    1.了解情况发生时间:询问客户发现异常事件的具体时间,后续的操作要基于此时间点进行追踪分析。受影响系统类型:询问具体的操作系统类型及相关情况,以便后续的应急处置。windows/linux财务系统/OA系统/官网,系统重要性,是否可关停是否有弱口令,远程管理端口是否开放都开放了什么端口,有什么......
  • 渗透测试基本流程
    渗透测试基本流程1.明确目标2.分析风险,获得授权3.信息收集4.漏洞探测(手动&自动)5.漏洞验证6.信息分析7.利用漏洞,获取数据8.信息整理9.形成报告1.明确目标1)确定范围:测试的范围,如:IP、域名、内外网、整站or部分模块;2)确定规则:能渗透到什么程度(发现漏洞为止or继续利用漏洞)、时间限制、能......
  • 如何使用Nmap加强网络安全?
    Nmap是NetworkMapper(网络映射器)的缩写,是一个用于端口和IP扫描以及应用程序检测的开源工具。网络和系统管理员将其用于清点网络资产、管理服务升级计划和监视服务正常运行时间。起初,它是作为一款Linux工具而开发的,但现在也可用于Windows和MacOS。用户还可以在Solaris、AIX或AmigaO......
  • 记使用Arthas定位并解决Java应用死锁问题
    背景在一次生产环境部署后,我们的JavaWeb应用开始表现出严重的性能下降。用户报告说网页响应变得非常慢,有时甚至完全无响应。初步检查服务器资源和应用日志未发现明显的问题,我们怀疑可能是应用内部出现了死锁。引入Arthas为了不影响生产环境运行,我们决定使用Arthas进行问题诊断。Ar......
  • SpringBoot中使用SpringEvent业务解耦神器实现监听发布事件同步异步执行任务
    场景SpringBoot中使用单例模式+ScheduledExecutorService实现异步多线程任务(若依源码学习):https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/135504554设计模式-观察者模式在Java中的使用示例-环境监测系统:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/det......
  • 使用 Microsoft Graph oFFICE365 sendmail C#
    usingMicrosoft.Graph;usingAzure.Identity;usingMicrosoft.Graph.Models;varscopes=new[]{"https://graph.microsoft.com/.default"};vartenantId="{tenantid}";//ValuesfromappregistrationvarclientId="{clientid}&qu......