sqlmap学习笔记

sqlmap是一款强大的SQL注入工具,支持五种注入模式:布尔盲注、时间盲注、报错注入、联合查询注入和堆查询注入。它能检测多种数据库,包括MySQL、Oracle等,并提供检测注入点、跟随302跳转、cookie注入和从POST数据包中注入等功能。通过设置不同选项,可以进行详细的数据库枚举、优化性能、蛮力检查以及访问文件系统和操作系统。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ps:学习sqlmap前,建议了解SQL注入实现原理与基本的手工注入操作,更易于理解sqlmap的使用。

sqlmap简介

sqlmap支持五种不同的注入模式:

1.基于布尔的盲注,即可以根据返回页面判断条件真假的注入。
2.基于时间的盲注,即不能根据页面返回内容判断任何信息,用条件语句查看时间延迟语句是否执行(即页面返回时间是否增加)来判断。
3.基于报错注入,即页面会返回错误信息,或者把注入的语句的结果直接返回在页面中。
4.联合查询注入,可以使用union的情况下的注入。
5.堆查询注入,可以同时执行多条语句的执行时的注入。

sqlmap支持的数据库有:
MySQL, Oracle, PostgreSQL, Microsoft SQL Server, Microsoft Access, IBM DB2, SQLite, Firebird, Sybase和SAP MaxDB


1.检测注入点

基本格式

默认使用level1检测全部数据库类型

sqlmap -u "http://test.php?id=1​"

指定数据库类型为mysql,级别为3(共5级,级别越高,检测越全面)

sqlmap -u "http://test.php?id=1"  –dbms mysql –level 3

2.跟随302跳转

当注入页面错误的时候,自动跳转到另一个页面的时候需要跟随302,
当注入错误的时候,先报错再跳转的时候,不需要跟随302。
目的就是:要追踪到错误信息。

3.cookie注入

当程序有防get注入的时候,可以使用cookie注入

sqlmap -u "URL​" --cookie "id" --level 2

(只有level达到2才会检测cookie)

4.从post数据包中注入

可以使用burpsuite或者temperdata等工具来抓取post包
1.指定username参数

sqlmap -r 'c:\tools\request.txt' -p "username" --dbms mysql

2.注入成功后,获取数据库基本信息,查询有哪些数据库

sqlmap -u "http://www.vuln.cn/post.php?id=1​"  --dbms mysql --level 3 --dbs

3.查询test库中有哪些表

sqlmap -u "http://www.vuln.cn/post.php?id=1​"  --dbms mysql --level 3 -D test --tables

-D 指定库名;--tables 列表

4.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值