SQL Server应用程序的高级Sql注入

作者:Chris Anley luoluo 来源: * 八进制 时间:2009-04-11 16:54:00 

[概 要]

这篇文章讨论常用的"sql注入"技术的细节,应用于流行的Ms IIS/ASP/SQL-Server平台。这里探讨有关这种攻击各种可以注入程序访问数据和数据库防范的方法。这篇文章面向两种读者:一是基于数据库web程序开发人员和审核各种web程序的安全专家。

[介 绍]

结构化查询语言(SQL)是一种用来和数据库交互的文本语言SQL语言多种多样,大多的方言版本都共同宽松地遵循SQL-92标准(最新的ANSI标准[译者注:目前最新的是SQL-99])。SQL运行的典型的操作是“查询”,它是可以让数据库返回“查询结果记录集”的语句集合。SQL语句可以修改数据库的结构(用数据定义语言"DDL")和操作数据库里的数据(用数据操作语言"DML")。我们在这里着重讨论Transact-SQL(交互式SQL),应用于SQL-Server的SQL一种方言(非标准SQL)。如果攻击者可以插一系列的SQL语句进入应用程序的数据查询时,Sql注入攻击就可能发生。

一个典型的SQL语句是这样的:
select id, forename, surname from authors
这个查询语句将会从'authors'表中返回'id','forename'和'surname'列的所有行。返回的结果集也可以加以特定条件'author'限制:
select id, forename, surname from authors where forename = 'john' and surname = 'smith'
注意这里很重要的一点是'john'和'smith'是被单引号引住的,假设'forename'和'surname'字段是来自于用户的输入,攻击者就可能通过输入非法字符串来对这个查询进行SQL注入:
Forename:jo'hn
Surname: smith

查询语句就会变成:
select id, forename, surname from authors where forename = 'jo'hn' and surname = 'smith'

当数据库试图执行这个查询,它会返回这样的错误:
Server:Msg 170, Level 15, State 1, Line 1
Line 1:Incorrect syntax near 'hn'
这是因为插入的单引号破坏了原来单引号引住的数据,数据库执行到'hn'时失败。如果攻击者这样输入:
Forename: jo'; drop table authors--
Surname:
...authors表就会被删掉,原因过一会再解释。

似乎通过删除用户输入的字符串中的单引号或者通过一些方法避免它们出现可以解决这个问题。诚然如此,但是要实施这个解决方法还有很多的困难。因为首先:不是所有的用户提交的数据都是字符串形式,比如我们的用户输入通过'id'(看上去是个数字)来选择一个用户,我们的查询可能会这样:
select id,forename,surname from authors where id=1234
在这种情况下攻击者可以轻易的在数值输入后面添加SQL语句。在其他SQL方言中,使用着各种分隔符,比如MS Jet DBMS引擎,日期可以用'#'符号来分隔。

其次,避免单引号并不像开始我们想象的那样是必要的解决办法,原因下面讨论。

标签:SQL,Server,应用程序,Sql注入
0
投稿

猜你喜欢

  • VBScript GetObject 函数用法介绍

    2008-01-30 17:00:00
  • 利用后缀表达式(逆波兰式)算24点的JavaScript版算法

    2010-01-23 10:57:00
  • DW自带的行为制作弹出菜单

    2008-05-16 11:38:00
  • 关于分页

    2011-07-01 12:39:03
  • Python保存数据至MySQL时中文问题

    2011-02-23 12:06:00
  • SQL Server 2005数据库镜像配置脚本示例

    2008-04-12 14:49:00
  • 关于Javascript的内存泄漏问题

    2008-04-15 07:46:00
  • 页面软键盘汉字输入

    2010-09-01 20:41:00
  • 经验总结:修改MySQL默认密码的具体步骤

    2009-01-04 13:29:00
  • Oracle DBA常用语句第1/2页

    2009-08-08 22:38:00
  • 求任意自然数内的素数

    2009-10-15 12:21:00
  • IE下中英文字体不能对齐原因及解决

    2008-08-11 12:47:00
  • 鼠标驱动图片变化

    2009-07-26 10:03:00
  • 在ASP中使用SQL语句之4:联合语句

    2007-08-11 12:34:00
  • 面向站长和网站管理员的Web缓存加速指南[翻译]

    2008-04-22 21:04:00
  • 根据时段自动切换你的站点CSS皮肤风格

    2007-09-20 18:08:00
  • JavaScript程序执行顺序问题总结

    2010-01-29 13:06:00
  • 用户体验如何提升阿里巴巴的商业价值

    2009-07-23 20:29:00
  • 禁用JavaScript脚本来复制网站内容

    2007-02-03 11:30:00
  • 通过T_sql语句向其中一次填入一条数据或一次填入多条数据的方式填充数据

    2012-11-30 19:55:34
  • asp之家 网络编程 m.aspxhome.com