什么是简单的分析SQL注入漏洞

如今非常多人在入侵的过程中基本都是通过SQL注入来完毕的,可是有多少人知道为什么会有这种注入漏洞呢?有的会随口说着对于字符的过滤不严造成的。

可是事实是这样吗?我们学这些。不仅要知其然。更要知其所以然!理论联系实际,才干对我们技术的提高有所帮助。

步骤/方法

1、SQL注入。因为程序在实际使用中,为了管理庞大的数据信息,就会使用到数据库。数据库能够方便程序对全部数据信息进行统一的存储和分类组织。便于查询更新。

用户在使用程序时,程序能够自己主动通过对数据库的查询,将所获得的信息依照一定格式反馈给用户,同一时候用户也是通过交互式的对话框提交给程序数据。从而使程序依照用户想要的信息进行查询。反馈给用户想要的信息。


对于程序这样的数据库操作。先来看一段代码:
strKeyword = Request ["keyword"];
sqlQuery = "SELECT * FROM Aritcles WHERE Keywords LIKE '%" +strKeyword + "%'";
这段代码的主要目的是依照用户提交的keywordKeyword。对软件连接数据库中的文件进行搜索,找出全部包括用户keyword的文章来。如果此时。我们提交给软件“hack”这个数据,这时,“hack”这个keyword就会被传递给Keyword关键变量。接下来看看代码的运行情况。keyword获得数据“hack”后。被赋值给strKeyword变量。然后strKeyword变量被放入查询语句。此时的查询语句表现为:"SELECT * FROM Aritcles WHERE Keywords LIKE '%hack%'",这个查询语句的意思就是从数据库Aritcles表中查询出全部包括“hack”这个keyword的文章。注意“hack”这个单词是我们提交给程序的,因此能够对其任意改动的。于是。能够这样改动,把它变为“hack'; DROP TABLE Aritcles; --”。


如今看看程序会如何处理这个外部keyword数据。

首先。查询语句变成了:“SELECT * FROM Aritcles WHERE Keywords LIKE '%hack%'; DROP TABLE Aritcles; --”。我们知道DROP TABLE语句是在数据库操作中删除一个指定的表的意思。如今那个查询语句的意思就变了。以中间的分号为标志。分成两个部分。首先还是正常的查出全部包括hackkeyword的文章。可是接下来……


因为程序使用的数据库是微软的SQL SERVER,该数据库支持多命令语句运行。这些数据库操作的命令语句都是由分号分隔开。然后依次运行的。

这里的“DROP TABLE Aritcles; --”是一个全然合法的命令语句,“--”符号是SQL SERVER数据库特有凝视标识,数据库不运行不论什么命令。这样,当这段查询语句运行时,就会去运行一个删除Aritcles表的数据库命令。


像这样,通过控制传递给程序数据库操作语句的关键变量来获得恶意控制程序数据库,从而获取实用信息或者制造恶意破坏的,甚至是控制用户计算机系统的漏洞,就称之为“SQL注入漏洞”。
SQL注入漏洞全然是利用了将包括了某种目的的SQL语句,通过关键变量插入到程序中正常的数据库操作语句里。

程序一旦发生注入漏洞,就会引发一系列安全隐患。


SQL注入漏洞是不分语言的,不管用什么语言开发的程序,仅仅要涉及对数据库的操作。都可能存在SQL注入漏洞。

尽管有时会由于编写语言的要求。或者程序设置环境的不同。导致SQL注入漏洞非常难被经常使用的方法利用,可是总能够找到突破的方法。

2、以下以站点程序为例。看一看SQL注入漏洞最常常被利用的地方。也是危害最大的地方。
都知道对于一个站点来说,能够说数据库存放着站点全部的信息,WEB应用程序全然是凭借数据库中的信息进行正常的执行的。一个站点程序中,最关键的一个部分就是对用户的合法性的推断,也就是看訪问它的用户是不是一个注冊的用户。

这个时候。就会要求输入username和password,然后依据输入的信息查询数据库。推断是否存在用户,并检查password是不是一致,假设一致则承认合法用户。否则将给予非法提示。以下看一段经常出如今论坛程序中的用户认证程序代码:
(1)admin1 = trim(request("name"))
(2)password1 = trim(request("password"))
(3)Set rs = Server.CreateObject ("ADODB.Recordset")
(4)sql = "select * from userlogin where name='"&admin1&"' and password='"&password1&"'"
(5)rs.Open sql,conn,1,1
(6)if rs.eof and rs.bof then
(7)response.write"<SCRIPT language=JavaScript>alert('username或password不对!')"
(8)response.write"javascript:history.go(-1)</SCRIPT>"
(9)response.end
(10)else
(11)session("name")=rs("name")
(12)session("password")=rs("password")
(13)response.Redirect("default.asp")
(14)end if
这段程序的第1和第2行分别通过Request对象获得username和password,第3行是建立一个数据库操作集对象。第4行就是将username以及password同一时候作为查询条件放入到userlogin表中进行查询,第5到第14行就是依据查询结果进行推断,弹出警告窗体。或者重定向网页。
如果数据库中有个用户guest。密码123456,那么该用户登录时,认证代码中的第4行则变为:sql = "select * from userlogin where name='guest' and password='123456'"。这是一个合法查询语句。所以用户能正常登录。反之则登录不了。


看起来这是一个比較严格的认证代码,可是事实呢?
如今,我们username提交“'or 1='1”,password也是一样,相同也会成为合法用户。这是为什么?
当我们提交表单后,代码通过Request对象获得提交的username'or 1='1以及password'or 1='1后,直接将这些数据放入了第4行的查询语句中,于是变成了这样:sql = "select * from userlogin where name=''or 1='1' and password=''or 1='1'"。我们先看1='1',这个绝对永远为真,假设你说假。那么你回小学学数学吧,学好再来看吧,呵呵~注意在大马前面另一个or,这代表者1='1'是作为一个条件选择语句放入数据库查询的,这样不管查询语句中的username与password是否正确。都会由于or后面的1='1'代码,导致查询语句返回值永远为真,这样就是绕过了看似严格的用户认证,获得了合法的权限。

注意事项

非常多软件程序与站点程序一样,都具实用户登录这种机制,假设软件的登录功能与上述的一样存于SQL注入漏洞的话,然后,该软件无用的登录功能

版权声明:本文博主原创文章。博客,未经同意不得转载。

转载于:https://www.cnblogs.com/zfyouxi/p/4817309.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/574307.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python发布服务,Python服务发现:在本地n上发布服务

在本地网络上执行服务通告/发现的一个简单方法是广播UDP包。常数&#xff1a;PORT 50000MAGIC "fna349fn" #to make sure we dont confuse or get confused by other programs公告&#xff1a;from time import sleepfrom socket import socket, AF_INET, SOCK_DGR…

[codevs1262] 不要把球传我 数论+组合数学

没什么好说的&#xff0c;很容易分析出递推公式f[n](n-2)*(n-1)*(n-3) div 6; 代码 beginreadln(n);     writeln((n-2)*(n-1)*(n-3) div 6);end. 巨短&#xff0c;就是这样233&#xff08;&#xff09; 我不会告诉你这一张是…

php可以用水晶报表吗,什么是水晶报表与水晶报表功能分析

水晶报表水晶报表(Crystal Report)是业内最专业、功能最强的报表系统&#xff0c;它除了强大的报表功能外&#xff0c;最大的优势是实现了与绝大多数流行开发工具的集成和接口。在VS.Net平台做过报表开发的程序员&#xff0c;一定都对水晶报表强大、高效、集成等特性留下了深刻…

大数据笔记11:MapReduce的运行流程

1.基本概念 &#xff08;1&#xff09;Job & Task &#xff08;2&#xff09;JobTracker &#xff08;3&#xff09;TaskTracker转载于:https://www.cnblogs.com/hebao0514/p/4825280.html

php 表格分页代码,[Php]分页及表格样式

writer:web wu 2007/11/29这个分页代码比较简单一些.操作用户列表include "conn.php"; //连接数据库文件mysql_select_db("admin"); //打开数据表$ssqlmysql_query("select count(*) as amcount from alluser",$con); //统计记录数if($my…

iPhone屏幕尺寸、分辨率及适配

目录(?)[-] iPhone尺寸规格单位inch英吋iPhone手机宽高屏幕尺寸像素密度PPI缩放因子scale factor between logic point and device pixel1Scale起源 2UIScreenscale 3UIScreennativeScale 4机型判别Resolutions Rendering2x3x以及高倍图适配12x 23x 3高倍图文件…

oracle中的and用法,Oracle bitand( )函数简介

Oracle bitand( )函数在Oracle数据库中是很常见的&#xff0c;下面就为您详细介绍Oracle bitand( )函数的用法&#xff0c;如果您感兴趣的话&#xff0c;不妨一看。Oracle bitand( )函数&#xff1a;返回两个数值型数值在按位进行AND 运算后的结果。语法BITAND(nExpression1, n…

Nagios显示器mysql定从库: libmysqlclient.so.18: cannot open shared object file: No such

做mysql的slave时间监控&#xff0c;必须check_mysql文字&#xff0c;check当误差&#xff1a;error while loading shared libraries: libmysqlclient.so.18: cannot open shared object file: No such file or directory1&#xff0c;错误信息例如以下&#xff1a;[rootslave…

oracle包如何进入编辑,修改 Oracle 的process和Session

1.process 和session的概念:process:这个参数限制了能够连接到SGA的操作系统进程数(或者是Windows 系统中的线程数),这个总数必须足够大,从而能够适用于后台进程与所有的专用服务器进程,此外,共享服务器进程与调度进程的数目也被计算在内.此外,共享 服务器进程与调度进程的数目…

Head First Python学习笔记4——处理数据

有这么几组数据需要你处理&#xff1a; James  2-34,3:21,2.34,2.45,3.01,2:01,2:01,3:10,2-22 Julia   2.59,2.11,2:11,2:23,3-10,2-23,3:10,3.21,3-21 Mikey  2:22,3.01,3:01,3.02,3:02,3.02,3:22,2.49,2:38 Sarah  2:58,2.58,2:39,2-25,2-55,2:54,2.18,2:55,2:55 这…

oracle ora 00910,NVARCHAR2字段超长问题:ORA-00910: specified length too long for its datatype

NVARCHAR2字段超长问题&#xff1a;ORA-00910: specified length too long for its datatype前几天在IMP的时候遇到了个问题&#xff1a;IMP-00017: following statement failed with ORACLE error 910:"CREATE TABLE "T_CSL_DYNAITEMDATAENTRY" ("FID&quo…

Swift - 触摸事件(点击,移动,抬起等)说明及用例

在iOS开发中&#xff0c;UIGestureRecognizer可以方便的响应处理手势事件。 而如果要想更精细的处理&#xff0c;我们还需要借助touchesBegan&#xff0c;touchesMoved&#xff0c;touchesEnded等触摸方法。这些方法 都是UIResponder中的方法。视图控制器和视图类&#xff0c;都…

鼠标移动响应php程序,jQuery实现的响应鼠标移动方向插件用法示例【附源码下载】...

本文实例讲述了jQuery实现的响应鼠标移动方向插件用法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;HTML代码如下&#xff1a;www.jb51.net jQuery响应鼠标移动*{margin:0;padding:0;}ul,li{list-style:none;}div{font-family:"Microsoft YaHei";}html,bo…

读《大道至简—是懒人造就了方法 》有感

读了大道至简第一章编程的精义之后&#xff0c;我觉得感触颇深&#xff0c;于是乎我又读了第二章是懒人造就了方法 &#xff0c;之后果然没有让我失望&#xff0c;第二章写的也是非常的好&#xff0c;非常的吸引我。 第二章的开头便引用了李冰凿山的故事&#xff0c;在战国时代…

《大道至简》第二篇读后感

今天把周爱民大道至简的第二章关于是懒人造就了方法读了几遍&#xff0c;作者通过战国时李冰凿山与愚公移山的比较来阐述懒人早就方法主题&#xff0c;以前听历史老师讲课的时候正是因为懒人才会有那么多可以节省人们力气和时间的发明&#xff0c;但懒人并不是真的懒&#xff0…

oracle备份磁盘头,ASM 磁盘头信息备份

ASM磁盘头信息保存在每个磁盘的前4K里面&#xff0c;这个信息的备份对于ASM的恢复非常重要&#xff0c;有下面的几种方法1.直接做dd来备份磁盘的前4K&#xff0c;磁盘头信息丢失时&#xff0c;dd回来 备份&#xff1a;dd if/dev/raw/raw1 of/gyj/asmheader.dd bs4096 coun…

var s=+newDate();的用法,表示对应的时间截

var snewDate(); var snewDate(); 解释如下:是不存在的; new Date()是一个东西; 相当于.valueOf(); 看到回复补充一下.getTime()这个也是得到毫秒数 //4个结果一样返回当前时间的毫秒数alert(new Date());alert(new Date);var snew Date();alert(s.valueOf()); alert(s.getTime…

asp控制oracle,asp下用OracleInProcServer完成对Oracle的连接和操作

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼tblnamerequest("tb")Dim objOraSession,objOraDbDim strDbUser,strDbPwd,strDbConnCall ConnectDB()Sub ConnectDB() 连接数据库On Error Resume NextstrDbUser "liujincai" 连接用户名strDbPwd "ljc1…

jitpack让使用第三方依赖库更简单

在开发过程中&#xff0c;使用第三方优秀依赖库是个很常见的问题&#xff0c;有的时候是maven&#xff0c;或者gradle, 或者sbt,大部分库工程&#xff0c;都会有对应的gradle,maven依赖代码&#xff0c;但是有的没有&#xff0c;尤其是使用的snapshot的依赖的时候&#xff0c;虽…

linux用户命令快捷链接,linux简单命令

linux系统命令是最基础也是最重要的部分&#xff0c;下面由学习啦小编为大家整理了linux简单命令的相关知识&#xff0c;希望对大家有帮助!linux简单命令一、文件和目录家目录为 /home/user 或者 &#xff5e;目录分为两种&#xff1a;绝对目录&#xff0c;从根目录开始写相对目…