当然,这只是传入参数是数字型的时候用的判断方法,实际应用的时候会有字符型和搜索型参数,我
将在中级篇的“SQL注入一般步骤”再做分析。
第三节、判断数据库类型及注入方法
不同的数据库的函数、注入方法都是有差异的,所以在注入之前,我们还要判断一下数据库的类型。
一般ASP最常搭配的数据库是Access和SQLServer,网上超过99%的网站都是其中之一。
怎么让程式告诉您他使用的什么数据库呢?来看看:
SQLServer有一些系统变量,假如服务器IIS提示没关闭,并且SQLServer返回错误提示的话,那能够
直接从出错信息获取,方法如下:
http://www.mytest.com/showdetail.asp?id=49 ;and user>0
这句语句很简单,但却包含了SQLServer特有注入方法的精髓,我自己也是在一次无意的测试中发现
这种效率极高的猜解方法。让我看来看看他的含义:首先,前面的语句是正常的,重点在and user>0,我
们知道,user是SQLServer的一个内置变量,他的值是当前连接的用户名,类型为nvarchar。拿一个
nvarchar的值跟int的数0比较,系统会先试图将nvarchar的值转成int型,当然,转的过程中肯定会出错
,SQLServer的出错提示是:将nvarchar值 ”abc” 转换数据类型为 int
的列时发生语法错误,呵呵,abc正是变量user的值,这样,不废吹灰之力就拿到了数据库的用户名。在
以后的篇幅里,大家会看到很多用这种方法的语句。
顺便说几句,众所周知,SQLServer的用户sa是个等同Adminstrators权限的角色,拿到了sa权限,几
乎肯定能够拿到主机的 Administrator了。上面的方法能够很方便的测试出是否是用sa登录,要注意的是
:假如是sa登录,提示是将”dbo”转换成int的列发生错误,而不是”sa”。
假如服务器IIS不允许返回错误提示,那怎么判断数据库类型呢?我们能够从Access和SQLServer和区
别入手,Access和
SQLServer都有自己的系统表,比如存放数据库中任何对象的表,Access是在系统表[msysobjects]中,但
在Web环境下读该表会提示“没有权限”,SQLServer是在表[sysobjects]中,在Web环境下可正常读取。
在确认能够注入的情况下,使用下面的语句:
http://www.mytest.com/showdetail.asp?id=49 ;and (select count(*) from sysobjects)>0
http://www.mytest.com/showdetail.asp?id=49 ;and (select count(*) from msysobjects)>0
假如数据库是SQLServer,那么第一个网址的页面和原页面http://www.mytest.com/showdetail.asp?
id= 49是大致相同的;而第二个网址,由于很难找到表msysobjects,会提示出错,就算程式有容错处理,
页面也和原页面完全不同。
假如数据库用的是Access,那么情况就有所不同,第一个网址的页面和原页面完全不同;第二个网址
,则视乎数据库配置是否允许读该系统表,一般来说是不允许的,所以和原网址也是完全不同。大多数情
况下,用第一个网址就能够得知系统所用的数据库类型,第二个网址只作为开启IIS错误提示时的验证。
进阶篇
在入门篇,我们学会了SQL注入的判断方法,但真正要拿到网站的保密内容,是远远不够的。接下来
,我们就继续学习如何从数据库中获取想要获得的内容,首先,我们先看看SQL注入的一般步骤:
第一节、SQL注入的一般步骤
首先,判断环境,寻找注入点,判断数据库类型,这在入门篇已讲过了。
其次,根据注入参数类型,在脑海中重构SQL语句的原貌,按参数类型主要分为下面三种:
(A) ID=49 这类注入的参数是数字型,SQL语句原貌大致如下:
Select * from 表名 where 字段=49
注入的参数为ID=49 And [查询条件],即是生成语句:
Select * from 表名 where 字段=49 And [查询条件]
(B) Class=连续剧 这类注入的参数是字符型,SQL语句原貌大致概如下:
Select * from 表名 where 字段=’连续剧’
注入的参数为Class=连续剧’ and [查询条件] and ‘’=’ ,即是生成语句:
Select * from 表名 where 字段=’连续剧’ and [查询条件] and ‘’=’’
© 搜索时没过滤参数的,如keyword=关键字,SQL语句原貌大致如下:
Select * from 表名 where 字段like ’%关键字%’
注入的参数为keyword=’ and [查询条件] and ‘%’=’, 即是生成语句:
Select * from 表名 where字段like ’%’ and [查询条件] and ‘%’=’%’
接着,将查询条件替换成SQL语句,猜解表名,例如:
ID=49 And (Select Count(*) from Admin)>=0
假如页面就和ID=49的相同,说明附加条件成立,即表Admin存在,反之,即不存在(请牢记这种方法
)。如此循环,直至猜到表名为止。
文章整理:西部数码--专业提供域名注册、虚拟主机服务
表名猜出来后,将Count(*)替换成Count(字段名),用同样的原理猜解字段名。
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!




