Web应用手工渗透测试—用SQLMap进行SQL盲注测试

简介

  本文主要关注SQL注入,假设读者已经了解一般的SQL注入技术,在我之前的文章中有过介绍,即通过输入不同的参数,等待服务器的反应,之后通过不同的前缀和后缀(suffix and prefix )注入到数据库。本文将更进一步,讨论SQL盲注,如果读者没有任何相关知识储备,建议先去wikipedia学习一下。在继续之前需要提醒一下,如果读者也想要按本文的步骤进行,需要在NOWASP Mutillidae环境搭建好之后先注册一个NOWASP Mutillidae帐号。

  SQL注入前言

  本文演示从web界面注入SQL命令的方法,但不会直接连接到数据库,而是想办法使后端数据库处理程序将我们的查询语句当作SQL命令去执行。本文先描述一些注入基础知识,之后讲解盲注的相关内容。

  Show Time

  这里我以用户名“jonnybravo”和密码“momma”登录,之后进入用户查看页面,位于OWASP 2013 > A1 SQL Injection > Extract data > User Info。要查看用户信息,需要输入用户ID与密码登录,之后就可以看到当前用户的信息了。

  如我之前的文章所提到的那样,这个页面包含SQL注入漏洞,所以我会尝试各种注入方法来操纵数据库,需要使用我之前文章提到的后缀(suffix)与前缀(prefix)的混合。这里我使用的注入语句如下:

  Username: jonnybravo’ or 1=1; –

  该注入语句要做的就是从数据库查询用户jonnybravo,获取数据后立刻终止查询(利用单引号),之后紧接着一条OR语句,由于这是一条“if状态”查询语句,而且这里给出 “or 1=1”,表示该查询永远为真。1=1表示获取数据库中的所有记录,之后的;–表示结束查询,告诉数据库当前语句后面没有其它查询语句了。

  

图1 正常方式查看用户信息

  将payload注入后,服务器泄露了数据库中的所有用户信息。如图2所示:

  

图2 注入payload导致数据库中所有数据泄露

  至此,本文向读者演示了一种基本SQL注入,下面笔者用BackTrack和Samurai 等渗透测试发行版中自带的SQLmap工具向读者演示。要使用SQLmap,只需要打开终端,输入SQLmap并回车,如下图所示:

  如果读者首次使用SQLmap,不需要什么预先操作。如果已经使用过该工具,需要使用—purge-output选项将之前的输出文件删除,如下图所示:

  

图3 将SQLmap output目录中的原输出文件删除

本文会演示一些比较独特的操作。通常人们使用SQLmap时会直接指定URL,笔者也是用该工具分析请求,但会先用Burp查看请求并将其保存到一个文本文件中,之后再用SQLmap工具调用该文本文件进行扫描。以上就是一些准备工作,下面首先就是先获取一个请求,如下所示:

  GET /chintan/index.php?page=user-info.php&username=jonnybravo&password=

  momma&user-info-php-submit-button=View+Account+Details HTTP/1.1

  Host: localhost

  User-Agent: Mozilla/5.0 (Windows NT 5.1; rv:27.0) Gecko/20100101 Firefox/27.0

  Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8

  Accept-Language: en-US,en;q=0.5

  Accept-Encoding: gzip, deflate

  Referer: http://localhost/chintan/index.php?page=user-info.php

  Cookie: showhints=0; username=jonnybravo; uid=19; PHPSESSID=f01sonmub2j9aushull1bvh8b5

  Connection: keep-alive

  将该请求保存到一个文本文件中,之后发送到KALI linux中,用如下命令将该请求头部传给SQLmap:

  SQLmap –r ~/root/Desktop/header.txt

  命令中-r选项表示要读取一个包含请求的文件,~/root/Desktop/header.txt表示文件的位置。如果读者用VMware,例如在Windows上用虚拟机跑KALI,执行命令时可能产生如下图所示的错误提示:

  这里必须在请求头中指定一个IP地址,使KALI linux能与XP正常通信,修改如下图所示:

  之后命令就能正常执行了,显示结果如下图所示:

  基本上该工具做的就是分析请求并确定请求中的第一个参数,之后对该参数进行各种测试,以确定服务器上运行的数据库类型。对每个请求,SQLmap都会对请求中的第一个参数进行各种测试。

  GET /chintan/index.php?page=user-info.php&username=jonnybravo&password=momma&user-

  info-php-submit-button=View+Account+Details HTTP/1.1

  SQLmap可以检测多种数据库,如MySQL、Oracle SQL、PostgreSQL、Microsoft SQL Server等。

  下图是笔者系统中SQLmap正在对指定的请求进行检测时显示的数据库列表:

  首先它会确定给定的参数是否可注入。根据本文演示的情况,我们已经设置OWASP mutillidae的安全性为0,因此这里是可注入的,同时SQLmap也检测到后台数据库DBMS可能为MYSQL。

  如上图所示,工具识别后台数据库可能为MYSQL,因此提示用户是否跳过其它类型数据库的检测。

  “由于本文在演示之前已经知道被检测数据库是MYSQL,因此这里选择跳过对其它类型数据库的检测。”

  之后询问用户是否引入(include)测试MYSQL相关的所有payload,这里选择“yes”选项:

  测试过一些payloads之后,工具已经识别出GET参数上一个由错误引起的注入问题和一个Boolean类型引起的盲注问题。

  之后显示该GET参数username是一个基于MYSQL union(union-based)类型的查询注入点,因此这里跳过其它测试,深入挖掘已经找出的漏洞。

  至此,工具已经识别出应该深入挖掘的可能的注入点:

  接下来,我把参数username传递给SQLmap工具,以对其进行深入挖掘。通过上文描述的所有注入点和payloads,我们将对username参数使用基于Boolean的SQL盲注技术,通过SQLmap中的–technique选项实现。其中选择如下列表中不同的选项表示选用不同的技术:

  B : 基于Boolean的盲注(Boolean based blind)

  Q : 内联查询(Inline queries)

  T : 基于时间的盲注(time based blind)

  U : 基于联合查询(Union query based)

  E : 基于错误(error based)

  S : 栈查询(stack queries)

  本例中也给出了参数名“username”,因此最后构造的命令如下:

  SQLmap –r ~root/Desktop/header.txt – -technique B – -p username – -current-user

 这里-p选项表示要注入的参数,“–current-user“选项表示强制SQLmap查询并显示登录MYSQL数据库系统的当前用户。命令得到输出如下图所示:

  同时也可以看到工具也识别出了操作系统名,DBMS服务器以及程序使用的编程语言。

  “”当前我们所做的就是向服务器发送请求并接收来自服务器的响应,类似客户端-服务器端模式的交互。我们没有直接与数据库管理系统DBMS交互,但SQLmap可以仍识别这些后台信息。

  同时本次与之前演示的SQL注入是不同的。在前一次演示SQL注入中,我们使用的是前缀与后缀,本文不再使用这种方法。之前我们往输入框中输入内容并等待返回到客户端的响应,这样就可以根据这些信息得到切入点。本文我们往输入框输入永远为真的内容,通过它判断应用程序的响应,当作程序返回给我们的信息。“

  结果分析

  我们已经给出当前的用户名,位于本机,下面看看它在后台做了什么。前文已经说过,后台是一个if判断语句,它会分析该if查询,检查username为jonnybravo且7333=7333,之后SQLmap用不同的字符串代替7333,新的请求如下:

  page=user-info.php?username=’jonnybravo’ AND ‘a’='a’ etc..FALSE

  page=user-info.php?username=’jonnybravo’ AND ‘l’='l’ etc..TRUE

  page=user-info.php?username=’jonnybravo’ AND ‘s’='s’ etc..TRUE

  page=user-info.php?username=’jonnybravo’ AND ‘b’='b’ etc..FALSE

  如上所示,第一个和最后一个查询请求结果为假,另两个查询请求结果为真,因为当前的username是root@localhost,包含字母l和s,因此这两次查询在查询字母表时会给出包含这两个字母的用户名。

  “这就是用来与web服务器验证的SQL server用户名,这种情况在任何针对客户端的攻击中都不应该出现,但我们让它发生了。”

  去掉了–current-user选项,使用另外两个选项-U和–password代替。-U用来指定要查询的用户名,–password表示让SQLmap去获取指定用户名对应的密码,得到最后的命令如下:

  SQLmap -r ~root/Desktop/header.txt --technique B -p username -U root@localhost --passwords

  命令输出如下图所示:

  Self-Critical Evaluation

  有时可能没有成功获取到密码,只得到一个NULL输出,那是因为系统管理员可能没有为指定的用户设定认证信息。如果用户是在本机测试,默认情况下用户root@localhost是没有密码的,需要使用者自己为该用户设置密码,可以在MySQL的user数据表中看到用户的列表,通过双击password区域来为其添加密码。或者可以直接用下图所示的命令直接更新指定用户的密码:

  这里将密码设置为“sysadmin“,这样SQLmap就可以获取到该密码了,如果不设置的话,得到的就是NULL。

  通过以上方法,我们不直接与数据库服务器通信,通过SQL注入得到了管理员的登录认证信息。

  总结

  本文描述的注入方法就是所谓的SQL盲注,这种方法更繁琐,很多情况下比较难以检测和利用。相信读者已经了解传统SQL注入与SQL盲注的不同。在本文所处的背景下,我们只是输入参数,看其是否以传统方式响应,之后凭运气尝试注入,与之前演示的注入完全是不同的方式。

最新内容请见作者的GitHub页:http://qaseven.github.io/

时间: 2025-01-31 09:00:36

Web应用手工渗透测试—用SQLMap进行SQL盲注测试的相关文章

《重构HTML:改善Web应用的设计(修订版)》——2.3 测试

2.3 测试 从理论上讲,重构不应破坏任何未曾破坏的代码,然而在实践中并不是那样.在某种程度上,本书后面会向你展示哪些改动是安全的.但无论是人还是工具都会犯错误,重构也有可能引入新错误,所以重构过程就需要一个良好的自动化测试套件(suite).进行任何重构之后,你更希望可以通过单击一个按钮和扫视一眼就能看到是否有代码被破坏了. 尽管测试驱动开发(test-driven development)在传统程序员中取得了巨大的成功,但在Web开发者中还是不太常见,尤其对前端开发者而言.实际上,网站的任何

《Metasploit渗透测试手册》—第3章3.3节 在Windows XP SP2上进行渗透测试8.7 使用Metasploit进行模糊测试

3.3 在Windows XP SP2上进行渗透测试8.7 使用Metasploit进行模糊测试 Metasploit渗透测试手册 本节中我们将介绍如何使用Metasploit攻陷运行着Windows XP操作系统的目标机器,其中需要使用前面章节中讲到的一些命令,进一步选择漏洞利用代码和攻击载荷,并设置各种必需的参数. 准备 首先在msfconsole中进行渗透测试过程.启动控制台,扫描端口搜集目标机器的信息,前面已经详细讨论过端口扫描的相关内容,这里假设已搜集到目标机器的信息,并确定其运行的是

Sql server负载测试性能调整魔法棒

没有什么事情比这更糟了,采纳一个新的应用程序,而它的性能是如此的糟糕,导致业务在一片惊叫声中暂停.这并不是新出现的现象:这就是事实,我经常遇到这样的事实.我打赌你也曾经经历过.那么如何防止这些性能问题,有什么解决方案? 在这些应用程序"在惊叫声中暂停"的情况中,应用程序通常都已经在按照功能性分配的短暂的测试时间内进行过适当的测试了.但是充分吗?由于竞争和全球经济的原因,迅速应用于业务意味着只进行了最小化的测试.同样,最小化的测试也成为按时将应用程序发布给用户群体的可接受的风险之一.另一

第 3 章 sqlmap - automatic SQL injection and database takeover tool

目录 3.1. Installation 3.2. 开始入住实验 3.2.1. 测试脚本 3.2.2. sqlmap.ini 3.3. Request参数 3.3.1. --method, --data 3.3.2. --cookie 3.3.3. --referer 3.3.4. --user-agent 3.3.4.1. -a 3.3.5. --headers 3.3.6. --referer 3.3.7. auth 3.3.7.1. --auth-type 3.3.7.2. --auth-

junit4 测试类(A)的时候 测试结果报空指针异常

问题描述 junit4 测试类(A)的时候 测试结果报空指针异常 junit4 测试类(A)的时候 (A)中的方法引用了接口 然后用bebug测试的时候 到引用接口的那一行的时候就会报空指针异常 请问 有什么办法使他不报异常 而这个接口又不能去除掉 求解!!! 解决方案 http://bbs.csdn.net/topics/390786622

select-vs2010C#Web开发3个Dropdown控件从sql数据库中的4个表显示数据

问题描述 vs2010C#Web开发3个Dropdown控件从sql数据库中的4个表显示数据 实现效果:第一个下拉控件是选择学院,第二个下拉控件是选择系部,第三个下拉控件是选择班级.从网上找了个后台代码:前台: <%@ Page Language=""C#"" AutoEventWireup=""true"" CodeFile=""StudInfo.aspx.cs"" Inheri

安卓-Google CTS 测试中哪条/哪些case是测试root process的?

问题描述 Google CTS 测试中哪条/哪些case是测试root process的? Google CTS 测试中哪条/哪些case是测试root process的?

压力测试- andriod用junit如何实现框架测试?

问题描述 andriod用junit如何实现框架测试? 不用介绍junit的几个类和方法,求实现事件流测试的思路,比如monkey之类的压力测试,要自己编写有序的测试框架.junit可以做到测试apk的功能,性能,环境等吗? 解决方案 Junit测试框架黑马程序员_JUnit测试框架JUnit测试框架

求助:服务器安装完IIS,默认地址测试OK,修改地址后,测试网站,报下列错误。

问题描述 服务器安装完IIS,默认地址测试OK,修改地址后,测试网站,报下列错误.MicrosoftVBScript编译器错误错误'800a03f6'缺少'End'/iisHelp/common/500-100.asp,行242MicrosoftVBScript运行时错误错误'800a01ad'ActiveX部件不能创建对象:'msxml2.FreeThreadedDOMDocument.3.0'/inc/Dv_ClsMain.asp,行43 解决方案 解决方案二:语法错误/inc/Dv_Cls