如何使用SQLancer检测DBMS中的逻辑漏洞

安全 数据安全
Synthesized Query Lancer工具是一款针对数据库管理系统DBMS的自动化安全测试工具。

[[426270]]

关于SQLancer

SQLancer,全称为Synthesized Query Lancer,该工具是一款针对数据库管理系统DBMS的自动化安全测试工具。该工具可以帮助广大研究人员轻松识别应用程序实现中的逻辑漏洞。我们这里所指的逻辑漏洞,即能够导致DBMS获取错误结果集的安全漏洞(比如说忽略数据记录等等)。

SQLancer能够在下面两个阶段进行操作:

  • 数据库生成:此阶段的目标是创建一个填充有数据的数据库,并向DBMS输入测试用例以尝试识别和检测不一致数据库状态。随后,该工具将会创建一个随机表,并随机选择SQL语句来生成、修改和删除数据。除此之外,该工具还会使用其他类型的语句(如创建索引和视图以及设置DBMS特定选项的语句)来测试目标DBMS;
  • 测试:此阶段的目标是针对生成的数据库检测逻辑错误。

工具要求

  • Java 8或以上版本;
  • Maven(Ubuntu安装:“sudo apt install maven”);
  • 需要测试的DBMS(项目中带有SQLite,而SQLite是一款嵌入式DBMS)。

工具安装&使用

广大研究人员可以使用下列命令将该项目源码克隆至本地,然后创建一个JAR,并开启SQLancer来测试SQLite,此过程使用的是非优化引用引擎结构(NoREC):

  1. git clone https://github.com/sqlancer/sqlancer 
  2. cd sqlancer 
  3. mvn package -DskipTests 
  4. cd target 
  5. java -jar sqlancer-*.jar --num-threads 4 sqlite3 --oracle NoREC 

执行之后,工具每5秒会打印一次处理信息。SQLancer可能会找出SQLite中的漏洞,在报告漏洞信息之前,请确保处理信息仍在打印。我们可以按下CTRL + C组合键手动停止SQLancer的运行。如果SQLancer没有找出漏洞,那么它将会一直运行下去。我们可以使用“--num-tries”来控制SQLancer在找到多少漏洞之后停止运行。除此之外,我们也可以使用“--timeout-seconds”来指定SQLancer允许执行的最大超时。

如果SQLancer在没有参数的情况下执行,工具则会输出所有可用的选项和命令。

支持的DBMS

由于各种DBMS使用的SQL形式差异很大,因此需要针对不同的DBMS采用单独的实现方式:

  • SQLite
  • MySQL
  • PostgreSQL
  • Citus
  • MariaDB
  • CockroachDB
  • TiDB
  • DuckDB
  • ClickHouse

项目地址

SQLancer:【GitHub传送门

 

责任编辑:赵宁宁 来源: FreeBuf
相关推荐

2022-01-29 08:01:43

漏洞网络攻击

2021-02-07 14:39:22

Falco漏洞安全工具

2021-10-06 13:53:06

开源工具keimpx安全工具

2023-09-01 07:21:11

2016-06-07 10:47:42

2013-01-11 09:41:34

2023-08-23 12:38:10

2010-09-03 14:56:12

SQLSELECT语句

2015-08-05 15:10:24

UbuntuLVM

2014-12-16 10:28:49

2022-02-14 08:05:59

安全漏洞扫描工具Python

2017-07-19 11:11:40

CTS漏洞检测原理浅析

2018-07-17 14:46:10

Hystrix异常触发

2010-10-13 13:46:10

2014-01-08 09:33:57

重复IP地址IP检测

2017-08-03 11:00:20

2021-11-18 14:01:25

网络安全数据技术

2020-10-15 12:00:01

Python 开发编程语言

2013-12-02 13:55:23

任意跳转漏洞漏洞检测DOM跳转漏洞

2023-12-01 16:21:42

点赞
收藏

51CTO技术栈公众号