Kali学习笔记44:SQLMAP
SQLMAP漏洞检测技术:
1.基于布尔的盲注检测:' and 1=1 'and 1=2等
2.基于时间的盲注检测:' and (select * from (select(sleep(20)))a) --
3.基于错误的盲注检测:比如输入单引号报错
4.基于联合查询的检测:取决于开发者是否使用循环语句,如果使用,才可以查出多条信息
5.基于堆叠查询的检测:分号分隔SQL语句
SQLMAP支持几乎所有主流的数据库,但不包含NoSQL
演示示例先不采用DVWA,因为登陆DVWA需要身份认证,具体身份认证的方法在后面介绍
使用Metaploitable的Mutillidae:
首先要处理数据库的问题,这里是Mutillidar数据库有问题:
找到$dbname变量,更改一下就可以了:
http://192.168.232.129/mutillidae/index.php?page=user-info.php&username=1&password=2&user-info-php-submit-button=View+Account+Details
使用SQLMAP对它进行检测
命令:
sqlmap -u "http://192.168.232.129/mutillidae/index.php?page=user-info.php&username=1&password=2&user-info-php-submit-button=View+Account+Details" -p username -f
解析:-u输入猜测存在注入的URL,-p猜测存在注入的参数,-f使用指纹信息
结果如下:

基于错误,基于时间,基于联合查询判断出存在注入而且数据库为MySQL
指纹信息如下:

得知目标系统的语言和Web服务器,数据库版本等关键信息
这条命令最后的参数其实可以不用-f,我们可以使用其他的参数:
比如--users:查询目标数据库账号

比如--banner:获取banner信息,其实和上面结果差不多

再比如--dbs:目标数据库中有哪些库
这里查到7个库

还有--schema:查看元数据库
数据过多,我这里只展示其中一部分的数据库

最后一个参数-a:查看所有信息

没有结束,sqlmap接下来提示我们发现了哈希值,是否需要继续破解下去
我选择是,它会将哈希值存入一个本地文件中,并且允许sqlmap进行进一步的破解
使用默认字典,不适用密码前缀

由于我们使用的是-a参数,最终破解出了所有的数据库信息和带有哈希的密文
我们可以用sqlmap作为客户端直接连接目标数据库:
执行命令:
sqlmap -d "mysql://root:@192.168.232.129:3306/dvwa" -f --users
结果很快就可以出来,其他参数和上边提到的一样,都可以做到相关的操作,但是速度要比上面快得多
注入多个URL:
执行命令:
sqlmap -m list.txt --users
将多个URL存入list.txt,然后注入,后边的参数很前面提到的一样
以上的方式都是采用GET方式提交的URL,如果是采用POST方式提交的URL呢?
这里就需要结合Burpsuite工具了
找一个需要POST方法提交表单的注入URL:
http://192.168.232.129/mutillidae/index.php?page=login.php
使用Burp截获HTTP请求:

存入一个文本post.txt
然后就可以执行了:
命令:后边的参数还是可选的那些
sqlmap -r post.txt --users
第二种方式:
使用Burp的log文件:
首先我们到Burp的设置中配置Log:

然后使用命令:
sqlmap -l log.txt -p username
后面参数还是类似的,就可以对日志中的requests信息进行检测了
基于HTTPS的检测:
其实很简单,只需要加一个参数--force-ssl
扫描配置文件:
sqlmap -c config.txt
由于配置文件的参数过多,所以具体的使用方法会在后边介绍
可以来看看sqlmap的默认的配置文件:
查询位置,然后进入/etc/sqlmap/sqlmap.conf查看

后边内容就是围绕这个配置文件中的其他参数进行讲解
Kali学习笔记44:SQLMAP的更多相关文章
- [原创]java WEB学习笔记44:Filter 简介,模型,创建,工作原理,相关API,过滤器的部署及映射的方式,Demo
本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...
- CUBRID学习笔记 44 UPDATE 触发器 更新多表 教程
cubrid的中sql查询语法UPDATE c#,net,cubrid,教程,学习,笔记欢迎转载 ,转载时请保留作者信息.本文版权归本人所有,如有任何问题,请与我联系wang2650@sohu.com ...
- Kali学习笔记31:目录遍历漏洞、文件包含漏洞
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 目录遍历漏洞: 应用程序如果有操作文件的功能,限制不严 ...
- Kali学习笔记30:身份认证与命令执行漏洞
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 实验环境: Kali机器:192.168.163.13 ...
- Kali学习笔记29:默认安装漏洞
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 默认安装漏洞: 早期Windows默认自动开启很多服务 ...
- Kali学习笔记27:Burpsuite(上)
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 如果我只能选择一款工具进行Web渗透,那么一定就是Bu ...
- Kali学习笔记26:OWASP_ZAP
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 OWASP_ZAP扫描器不同于之前介绍的Web扫描器: ...
- Kali学习笔记25:Arachni使用(实现分布式扫描)
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 Arachni不同于上次介绍的nikto和skipfi ...
- Kali学习笔记24:Nikto、Skipfish
文章的格式也许不是很好看,也没有什么合理的顺序 完全是想到什么写一些什么,但各个方面都涵盖到了 能耐下心看的朋友欢迎一起学习,大牛和杠精们请绕道 实验环境: Kali机器IP:192.168.163. ...
随机推荐
- Qt之excel 操作使用说明
学习背景: 适合熟悉些qt开发,但是不是深入了解的开发者学习.具体实现(qt 5.1版本),office2007 Excel做验证,Win 7(64位),如有讲解有误,欢迎斧正! 一.简单介绍 QAx ...
- JS十种经典排序算法,纯动画演示,学会了怼死面试官!
十种常见排序算法可以分为两大类: 非线性时间比较类排序:通过比较来决定元素间的相对次序,由于其时间复杂度不能突破O(nlogn),因此称为非线性时间比较类排序. 线性时间非比较类排序:不通过比较来决定 ...
- Linux下使用http协议下载文件
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h&g ...
- Ansible入门篇:playbook的使用
playbooks介绍 playbooks是 一个不同于使用Ansible命令行执行方式的模式,其功能更强大灵活.简单来说,playbook是一个非常简单的配置管理和多主机部署系统,不同于任何已经存在 ...
- c++/qt的数据序列化和反序列化
序列化以及反序列化的实现 struct Body { double weight; double height; }; //结构体 struct People { int age; Body dBod ...
- avue的小白之路
经过几天的看实例,我稍稍了解到了avue,写这个博客主要是最近学习avue的一个总结.. avue是基于vue与element ui的一个框架,强烈建议等了解这其中道理在学习avue会事半功倍:这是我 ...
- scrapy + selenium 的动态爬虫
动态爬虫 在通过scrapy框架进行某些网站数据爬取的时候,往往会碰到页面动态数据加载的情况发生,如果直接使用scrapy对其url发请求,是绝对获取不到那部分动态加载出来的数据值.但是通过观察我们会 ...
- 基本排序算法(Java)
基本排序算法 (Java) 经过几次笔试,发现自己的Java基础有些薄弱,基本的排序算法掌握的还不够熟练,需要多加学习总结. 1. 选择排序 思想: 给定一个整数数组,例 int[] a ={38,6 ...
- ABC113 AK失败记
众所周知, ABC是一场水题盛宴, 也是一场AK盛宴. 但是我却没能AK. 原因也十分可笑: 我在一开始觉得题目太简单, 颓废了.直到我看了第4题之后才找到状态并A了此题...最后时间来不及第三题最后 ...
- Java 平时作业四
编写一个Java程序实现返回指定目录及其子目录下扩展名为*.pdf的所有文件名. 扩展: isFile public boolean isFile() 测试此抽象路径名表示的文件是否为普通文件. 如果 ...