2006-11-28

SQL概述及在网络安全中的应用(上)

来源: 赛迪 作者:yuanye 评论 0 条
 

SELECT查询被用于从数据库中获取信息.大多数的web应用程序通过SELECT向数据库获取信息候再动态地在页面上显示出来.通常,数据库查询这部分你可以自己伪造,他将成为WHERE子句的一部分.我们可以通过插入UNION SELECT来绕过web程序答应我们查询的数据,从而得到其它的数据.联合查询(指UNION SELECT)答应在一条语句中使用多个SELECT查询,看上去就像这样:

  SELECT CompanyName FROM Shippers

    WHERE 1 = 1 UNION ALL SELECT CompanyName FROM Customers WHERE 1 = 1

它返回的结果中包含了第一个查询和第二个查询的结果,"ALL SELECT"这里的ALL是必须的,这样可以逃过SELECT DISTINCT语句的限制并且不会妨碍别的(??),所以最好是使用它.你必须确认第一个查询,即web应用程序编写者希望执行的那个被执行,不返回任何记录.这并不难.举个例子,有这么一个表达式:

  SQLString = "SELECT FirstName, 

    LastName, Title FROM Employees WHERE City = '" & strCity & "'"

我们构造如下的插入串:

  ' UNION ALL SELECT OtherField FROM OtherTable WHERE ''='

这将导致如下的SQL查询语句被提交给SQL SERVER:

SELECT FirstName, LastName, 

Title FROM Employees WHERE City = '' 

UNION ALL SELECT OtherField FROM OtherTable WHERE ''=''

让我们看看会发生什么:数据库搜索Employees表,查找City被设置为NULL的那一行,由于它找不到哪一行city是NULL,所以它不会返回任何记录,只有我们inject的查询才会返回记录.在一些情况下,使用NULL不能成功,因为表里的却存在

有NULL的项.在这种情况下,你要做的就是构造一个表中不存在的值,你只要输入一些不普通的值...最好是对照那些正常的值,当数据库需要一个自然数时,0或者负数都工作得很好,对于一个文本参数,简单的用"NoSuchRecord","NotInTable"或更常见的"sjdajdhajsh",只要它不返回记录就好.

假如所有的web应用程序使用的SQL查询都像上面这些那么简单就好了,可惜这不可能: ].按照各个编程者习惯和查询表达式编写方式的不同,你SQL注射时可能会碰到各种困难.


共4页: 上一页 [1] [2] [3] 4 下一页

(本文仅表明作者个人观点,不代表本站及其管理员立场.) 推荐 收藏 投稿 打印 返回 关闭
上一篇:利用Xdebug和Komodo调试PHP应用程序  
下一篇:SQL注入奇招致胜 Union查询轻松看电影
    评论加载中…
 推荐文章
     

网站首页  -  网站地图 -   站长论坛  -  网站投稿  -    -  网站管理
Copyright © 2008 芜湖站长站 All Rights Reserved 皖ICP备07500611号