Sqlmap备忘单

Sqlmap常用参数及用法备忘单...

0x01 选项

1
2
3
4
5
6
7
8
9
10
11
Usage: python sqlmap.py [options]

Options(选项):

-h, ## 展示帮助文档参数

-hh ## 展示详细帮助文档参数

--version ## 显示程序的版本号

-v ## 详细级别:0-6(默认为1)

0x02 目标

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
Target(目标):

-d ## 指定具体数据库

-u URL ## 目标URL (e.g. "http://www.example.com/test.php?id=1")

-l ## 解析目标(s)从Burp或WebScarab代理日志文件

-x ## 从远程站点地图文件(.xml)解析目标

-m ## 扫描文本文件中给出的多个目标

-r ## 从本地文件加载HTTP请求 ,多用于post注入

-g ## 处理Google的结果作为目标URL

-c ## 从INI配置文件中加载选项

0x03 请求

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
Request(请求): 这些选项可以用来指定如何连接到目标URL

--method=METHOD ## 强制使用给定的HTTP方法(e.g. POST)

--data=DATA ## 通过POST发送的数据字符串

--param-del=PARA.. ## 用于拆分参数值的字符

--cookie=COOKIE ## Cookie头的值

--cookie-del=COO.. ## 用于分割Cookie值的字符

--load-cookies=L.. ## 包含Netscape/wget格式的cookie的文件

--drop-set-cookie ## 从响应中忽略Set-Cookie头

--user-agent=AGENT ## 指定 HTTP User - Agent头

--random-agent ## 使用随机选定的HTTP User - Agent头

--host=HOST ## HTTP主机头值

--referer=REFERER ## 指定 HTTP Referer头

-H HEADER, --hea.. ## 额外header (e.g. "X-Forwarded-For: 127.0.0.1")

--headers=HEADERS ## 额外header (e.g. "Accept-Language: fr\\nETag: 123")

--auth-type=AUTH.. ## 认证类型(Basic, Digest, NTLM or PKI)

--auth-cred=AUTH.. ## HTTP认证凭证(name:password)

--auth-file=AUTH.. ## HTTP认证 PEM认证/私钥文件

--ignore-401 ## 忽略HTTP错误401

--proxy=PROXY ## 使用代理连接到目标网址

--proxy-cred=PRO.. ## 代理认证证书(name:password)

--proxy-file=PRO.. ## 从文件中加载代理列表

--ignore-proxy ## 忽略系统默认代理设置

--tor ## 使用Tor匿名网络

--tor-port=TORPORT ## 设置Tor代理端口而不是默认值

--tor-type=TORTYPE ## 设置Tor代理类型

--check-tor ## 检查Tor是否正确使用

--delay=DELAY ## 每个HTTP请求之间的延迟(秒)

--timeout=TIMEOUT ## 秒超时连接前等待(默认30)

--retries=RETRIES ## 连接超时时重试(默认值3)

--randomize=RPARAM ## 随机更改给定参数的值(s)

--safe-url=SAFEURL ## 在测试期间频繁访问的URL地址

--safe-post=SAFE.. ## POST数据发送到安全URL

--safe-req=SAFER.. ## 从文件加载安全HTTP请求

--safe-freq=SAFE.. ## 在两次访问给定安全网址之间测试请求

--skip-urlencode ## 跳过有效载荷数据的URL编码

--csrf-token=CSR.. ## 参数用于保存anti-CSRF令牌

--csrf-url=CSRFURL ## 提取anti-CSRF URL地址访问令牌

--force-ssl ## 强制使用SSL /HTTPS

--hpp ## 使用HTTP参数pollution的方法

--eval=EVALCODE ## 评估请求之前提供Python代码(如"import hashlib;id2=hashlib.md5(id).hexdigest()")

0x04 性能优化

1
2
3
4
5
6
7
8
9
10
11
Optimization(优化): 这些选项可用于优化sqlmap的性能

-o ## 开启所有优化开关

--predict-output ## 预测常见的查询输出

--keep-alive ## 使用持久的HTTP(S)连接

--null-connection ## 从没有实际的HTTP响应体中检索页面长度

--threads=THREADS ## 最大的HTTP(S)请求并发量(默认为1)

0x05 注入

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
Injection(注入): 用来指定测试哪些参数,提供自定义的注入payloads和可选篡改脚本

-p ## 可测试的参数(S)

--skip=SKIP ## 跳过对给定参数的测试

--skip-static ## 跳过测试不显示为动态的参数

--param-exclude=.. ## 使用正则表达式排除参数进行测试(e.g. "ses")

--dbms=DBMS ## 强制后端的DBMS为此值

--dbms-cred=DBMS.. ## DBMS认证凭证(user:password)

--os=OS ## 强制后端的DBMS操作系统为这个值

--invalid-bignum ## 使用大数字使值无效

--invalid-logical ## 使用逻辑操作使值无效

--invalid-string ## 使用随机字符串使值无效

--no-cast ## 关闭有效载荷铸造机制

--no-escape ## 关闭字符串转义机制

--prefix=PREFIX ## 注入payload字符串前缀

--suffix=SUFFIX ## 注入payload字符串后缀

--tamper=TAMPER ## 使用给定的脚本(S)篡改注入数据

0x06 检测

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
Detection(检测): 用来指定在SQL盲注时如何解析和比较HTTP响应页面的内容

--level=LEVEL ## 执行测试的等级(1-5,默认为1)

--risk=RISK ## 执行测试的风险(0-3,默认为1)

--string=STRING ## 查询时有效时在页面匹配字符串

--not-string=NOT.. ## 当查询求值为无效时匹配的字符串

--regexp=REGEXP ## 查询时有效时在页面匹配正则表达式

--code=CODE ## 当查询求值为True时匹配的HTTP代码

--text-only ## 仅基于在文本内容比较网页

--titles ## 仅根据他们的标题进行比较

0x07 技巧

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Techniques(技巧): 用于调整具体的SQL注入测试。

--technique=TECH ## SQL 注入技术测试(默认BEUST)

--time-sec=TIMESEC ## DBMS响应的延迟时间(默认为5秒)

--union-cols=UCOLS ## 定列范围用于测试UNION查询注入

--union-char=UCHAR ## 用于暴力猜解列数的字符

--union-from=UFROM ## 要在UNION查询SQL注入的FROM部分使用的表

--dns-domain=DNS.. ## 域名用于DNS漏出攻击

--second-order=S.. ## 生成页面的URL搜索为second-order响应

0x08 指纹

1
2
3
Fingerprint(指纹)

-f ## 执行检查广泛的DBMS版本指纹

0x09 枚举

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
Enumeration(枚举): 用来列举后端数据库管理系统的信息、表中的结构和数据,还可以运行自己的SQL语句

-a, ## 检索一切

-b, ## 检索数据库管理系统的标识

--current-user ## 检索数据库管理系统的标识

--current-db ## 检索数据库管理系统当前数据库

-hostname ## 检索数据库服务器的主机名

--is-dba ## 检测DBMS当前用户是否DBA

--users ## 枚举数据库管理系统用户

--passwords ## 枚举数据库管理系统用户密码哈希

--privileges ## 枚举数据库管理系统用户的权限

--roles ## 枚举数据库管理系统用户的角色

--dbs ## 枚举数据库管理系统数据库

--tables ## 枚举的DBMS数据库中的表

--columns ## 枚举DBMS数据库表列

--schema ## 枚举数据库架构

--count ## 检索表的条目数

--dump ## 转储数据库管理系统的数据库中的表项

--dump-all ## 转储数据库管理系统的数据库中的表项

--search ## 搜索列(S),表(S)和/或数据库名称(S)

--comments ## 检索数据库的comments(注释、评论)

-D DB ## 要进行枚举的数据库名

-T TBL ## 要进行枚举的数据库表

-C COL ## 要进行枚举的数据库列

-X EXCLUDECOL ## 不进行枚举的数据库列

-U USER ## 用来进行枚举的数据库用户

--exclude-sysdbs ## 枚举表时排除系统数据库

--pivot-column=P.. ## 主列名称

--where=DUMPWHERE ## 使用WHERE条件进行表转储

--start=LIMITSTART ## 第一个查询输出进入检索

--stop=LIMITSTOP ## 最后查询的输出进入检索

--first=FIRSTCHAR ## 第一个查询输出字的字符检索

--last=LASTCHAR ## 最后查询的输出字字符检索

--sql-query=QUERY ## 要执行的SQL语句

--sql-shell ## 提示交互式SQL的shell

--sql-file=SQLFILE ## 从给定文件执行SQL语句

0x0A 蛮力检查

1
2
3
4
5
Brute force(蛮力): 可以被用来运行蛮力检查

--common-tables ## 检查存在共同表

--common-columns ## 检查存在共同列

0x0B 访问操作

访问文件系统

1
2
3
4
5
6
7
8
File system access(访问文件系统):
可以被用来访问后端数据库管理系统的底层文件系统

--file-read=RFILE ## 从后端的数据库管理系统文件系统读取文件

--file-write=WFILE ## 编辑后端的数据库管理系统文件系统上的本地文件

--file-dest=DFILE ## 后端的数据库管理系统写入文件的绝对路径

操作系统访问

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
Operating system access(操作系统访问): 可以用于访问后端数据库管理系统的底层操作系统

--os-cmd=OSCMD ## 执行操作系统命令

--os-shell ## 交互式的操作系统的shell

--os-pwn ## 获取一个OOB shell,meterpreter或VNC

--os-smbrelay ## 一键获取一个OOB shell,meterpreter或VNC

--os-bof ## 存储过程缓冲区溢出利用

--priv-esc Database process user privilege escalation
## 数据库进程用户权限提升

--msf-path=MSFPATH ## 本地的安装路径

--tmp-path=TMPPATH ## 远程临时文件目录的绝对路径

Windows注册表访问

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
Windows registry access(Windows注册表访问): 可以被用来访问后端数据库管理系统Windows注册表。

--reg-read ## 读一个Windows注册表项值

--reg-add ## 写一个Windows注册表项值数据

--reg-del ## 删除Windows注册表键值

--reg-key=REGKEY ## Windows注册表键

--reg-value=REGVAL ## Windows注册表项值

--reg-data=REGDATA ## Windows注册表键值数据

--reg-type=REGTYPE ## Windows注册表项值类型

0x0C 常用参数

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
General : 可以用来设置一些一般的工作参数

-s SESSIONFILE ## 保存和恢复检索会话文件的所有数据

-t TRAFFICFILE ## 记录所有HTTP流量到一个文本文件中

--batch ## 从不询问用户输入,使用所有默认配置

--binary-fields=.. ## 具有二进制值的结果字段

--charset=CHARSET ## 强制用于数据检索的字符编码

--crawl=CRAWLDEPTH ## 从目标网址开始抓取网站

--crawl-exclude=.. ## 正则表达式排除网页抓取

--csv-del=CSVDEL ## 分隔CSV输出中使用的字符

--dump-format=DU.. ## 转储数据的格式 (CSV (default), HTML or SQLITE)

--eta ## 显示每个输出的预计到达时间

--flush-session ## 刷新当前目标的会话文件

--forms ## 在目标网址上解析和测试表单

--fresh-queries ## 忽略在会话文件中存储的查询结果

--hex ## 使用DBMS hex函数进行数据检索

--output-dir=OUT.. ## 自定义输出目录路径

--parse-errors ## 解析和显示响应中的DBMS错误消息

--save=SAVECONFIG ## 保存选项到INI配置文件

--scope=SCOPE ## 使用正则表达式从提供的代理日志中过滤目标

--test-filter=TE.. ## 根据有效负载和/或标题(e.g. ROW)选择测试

--test-skip=TEST.. ## 根据有效负载和/或标题跳过测试(e.g. BENCHMARK)

--update ## 更新SqlMap

0x0D 杂项

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
Miscellaneous(杂项):

-z ## 使用简短的助记符 (如 "flu,bat,ban,tec=EU")

--alert=ALERT ## 在找到SQL注入时运行主机操作系统命令

--answers=ANSWERS ## 设置问题答案

--beep ## 发现SQL 注入时提醒

--cleanup ## 具体的UDF和表清理DBMS

--dependencies ## 检查是否缺少(非内核)sqlmap依赖关系

--disable-coloring ## 禁用控制台输出颜色

--gpage=GOOGLEPAGE ## 使用Google dork结果指定页码

--identify-waf ## 对WAF/IPS/IDS保护进行全面测试

--skip-waf ## 跳过启发式检测WAF/IPS/IDS保护

--mobile ## 通过HTTP User-Agent标头模仿智能手机

--offline ## 在离线模式下工作(仅使用会话数据)

--page-rank ## Google dork结果显示网页排名(PR)

--purge-output ## 安全地从输出目录中删除所有内容

--smart ## 只有在正启发式时才进行彻底测试

--sqlmap-shell ## 提示交互式 sqlmap shell

--wizard ## 给初级用户的简单向导界面

0xFF Reference