我的日常

登录/注册
您现在的位置:论坛 盖世程序员(我猜到了开头 却没有猜到结局) 盖世程序员 > SQL注入(转帖)
总共48087条微博

动态微博

查看: 1186|回复: 0

SQL注入(转帖)

[复制链接]

2

主题

0

听众

96

金钱

三袋弟子

该用户从未签到

跳转到指定楼层
楼主
发表于 2014-12-18 19:51:19 |只看该作者 |倒序浏览
原文地址:http://www.cnblogs.com/rush/archive/2011/12/31/2309203.html1.1.1 摘要
/ v3 Y  U0 q4 n" n2 e7 }8 ?* P% S' w7 ^- X/ E4 m
. ^0 z& u- O( r; s# h  R
1.1.2 正文

SQL Injection:就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。

具体来说,它是利用现有应用程序,将(恶意)的SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句。

首先让我们了解什么时候可能发生SQL Injection。

假设我们在浏览器中输入URL www.sample.com,由于它只是对页面的简单请求无需对数据库动进行动态请求,所以它不存在SQL Injection,当我们输入www.sample.com?testid=23时,我们在URL中传递变量testid,并且提供值为23,由于它是对数据库进行动态查询的请求(其中?testid=23表示数据库查询变量),所以我们可以该URL中嵌入恶意SQL语句。

现在我们知道SQL Injection适用场合,接下来我们将通过具体的例子来说明SQL Injection的应用,这里我们以pubs数据库作为例子。我们通过Web页面查询job表中的招聘信息,job表的设计如下:


9 F+ Z4 t# J4 |4 q

图1 jobs表

+ v" {; B: c' d) n+ r9 m

接着让我们实现Web程序,它根据工作Id(job_id)来查询相应的招聘信息,示意代码如下:

protected void Page_Load(object sender, EventArgs e){    if (!IsPostBack)    {        // Gets departmentId from http request.        string queryString = Request.QueryString["departmentID"];        if (!string.IsNullOrEmpty(queryString))        {            // Gets data from database.            gdvData.DataSource = GetData(queryString.Trim());            // Binds data to gridview.            gdvData.DataBind();        }    }}9 O. w2 r/ d/ }" [' n

现在我们已经完成了Web程序,接下来让我们查询相应招聘信息吧。


& l% C' V# E% g. t4 I# \

图2 job表查询结果

% o0 I' e# N! U: j# y( d9 b

如图所示,我们要查询数据库中工作Id值为1的工作信息,而且在页面显示了该工作的Id,Description,Min Lvl和Max Lvl等信息。

现在要求我们实现根据工作Id查询相应工作信息的功能,想必大家很快可以给出解决方案,SQL示意代码如下:


( y9 d2 z8 r* z0 G$ F+ GSELECT     job_id, job_desc, min_lvl, max_lvlFROM         jobsWHERE     (job_id = 1)
3 X; \5 d) G! K% ?0 ^9 l7 O/ {- U4 H( J

假设现在要求我们获取Department表中的所有数据,而且必须保留WHERE语句,那我们只要确保WHERE恒真就OK了,SQL示意代码如下:

2 K3 l- n" P2 e
SELECT     job_id, job_desc, min_lvl, max_lvlFROM         jobsWHERE     (job_id = 1) OR 1 = 1
8 X0 D% W. P; T+ P9 k: ?0 [

上面我们使得WHERE恒真,所以该查询中WHERE已经不起作用了,其查询结果等同于以下SQL语句。

& r) `& d& }  A
SELECT     job_id, job_desc, min_lvl, max_lvlFROM         jobs
& _+ S" L* L* e" l8 F

SQL查询代码实现如下:


- a8 c# i/ A5 `5 l2 |' vstring sql1 = string.Format(    "SELECT job_id, job_desc, min_lvl, max_lvl FROM jobs WHERE job_id='{0}'", jobId);6 \/ V. B* _0 W  R: B: N+ v$ Q

现在我们要通过页面请求的方式,让数据库执行我们的SQL语句,我们要在URL中嵌入恶意表达式1=1(或2=2等等),如下URL所示:

http://localhost:3452/ExcelUsingXSLT/Default.aspx?jobid=1'or'1'='1

  _! |6 |( m# ^

等效SQL语句如下:

6 w  X$ S- b' E, a* q
SELECT     job_id, job_desc, min_lvl, max_lvlFROM         jobsWHERE     job_id = '1' OR '1' = 1'1 M; W" R% L2 n# n/ Z9 x% r

图3 job表查询结果


* C4 e( [/ i1 Q* ^0 Q* ?7 q' N

现在我们把job表中的所有数据都查询出来了,仅仅通过一个简单的恒真表达式就可以进行了一次简单的攻击。

虽然我们把job表的数据都查询出来了,但数据并没有太大的价值,由于我们把该表临时命名为job表,所以接着我们要找出该表真正表名。

首先我们假设表名就是job,然后输入以下URL:

http://localhost:3452/ExcelUsingXSLT/Default.aspx?jobid=1'or 1=(select count(*) from job)--


$ n6 w2 Z  h" f3 @" l6 ^9 Q

等效SQL语句如下:

1 W6 n+ h1 Y; O- Y( r6 o9 e
SELECT       job_id, job_desc, min_lvl, max_lvl FROM         jobs WHERE      job_id='1'or 1=(select count(*) from job) --'. N; b4 L, K4 n+ }) K6 g* e' K

- I  I8 T1 C3 J% B1 o9 N

图4 job表查询结果

' q- y$ @9 [7 F) L4 W5 w

当我们输入了以上URL后,结果服务器返回我们错误信息,这证明了我们的假设是错误的,那我们该感觉到挫败吗?不,其实这里返回了很多信息,首先它证明了该表名不是job,而且它还告诉我们后台数据库是SQL Server,不是MySQL或Oracle,这也设计一个漏洞把错误信息直接返回给了用户。

接下假定表名是jobs,然后输入以下URL:

http://localhost:3452/ExcelUsingXSLT/Default.aspx?jobid=1'or1=(select count(*) from jobs) --


7 u) j5 E& D. ?

等效SQL语句如下:

. N% I0 J1 i8 s% W; q: |
SELECT       job_id, job_desc, min_lvl, max_lvl FROM         jobs WHERE      job_id='1'or 1=(select count(*) from jobs) --'0 _* j  O, F5 m* L3 R% a9 q

图5 job表查询结果

4 {1 y) U% I5 ?/ m& R8 ]' ~- H

现在证明了该表名是jobs,这可以迈向成功的一大步,由于我们知道了表名就可以对该表进行增删改操作了,而且我们还可以猜测出更多的表对它们作出修改,一旦修改成功那么这将是一场灾难。

现在大家已经对SQL Injection的攻击有了初步的了解了,接下让我们学习如何防止SQL Injection。

总的来说有以下几点:

1.永远不要信任用户的输入,要对用户的输入进行校验,可以通过正则表达式,或限制长度,对单引号和双"-"进行转换等。0 [, d. u0 N/ N) i( o
2.永远不要使用动态拼装SQL,可以使用参数化的SQL或者直接使用存储过程进行数据查询存取。3 e4 d: B! y  A2 x0 a4 ~8 z# n
3.永远不要使用管理员权限的数据库连接,为每个应用使用单独的权限有限的数据库连接。6 O6 N+ n# \- A# U
4.不要把机密信息明文存放,请加密或者hash掉密码和敏感的信息。
5 g, Q3 I2 l$ l' i+ E5.应用的异常信息应该给出尽可能少的提示,最好使用自定义的错误信息对原始错误信息进行包装,把异常信息存放在独立的表中。6 O& [: _- ]1 P6 H) O% i# ?

/ n- U8 M3 U" ~# C! R, s' }' j2 B1 ~+ K! R" ~

科帮网 1、本主题所有言论和图片纯属会员个人意见,与本社区立场无关
2、本站所有主题由该帖子作者发表,该帖子作者与科帮网享有帖子相关版权
3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和科帮网的同意
4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
7、科帮网管理员和版主有权不事先通知发贴者而删除本文


JAVA爱好者①群:JAVA爱好者① JAVA爱好者②群:JAVA爱好者② JAVA爱好者③ : JAVA爱好者③

快速回复
您需要登录后才可以回帖 登录 | 立即注册

   

关闭

站长推荐上一条 /1 下一条

发布主题 快速回复 返回列表 联系我们 官方QQ群 科帮网手机客户端
快速回复 返回顶部 返回列表