SQL注入相关的知识【Mysql为例子】
以DVWA的sql注入初级为例,结合网上搜索的相关利用方式,总结成这一篇文章,内容会有点跳跃。
大纲:
1.初级手工注入
2.order by的使用
3.union查询注意点
4.Mysql相关的注释用法(比如 ‘--’后面需要跟一个空格或者回车等)
5.Mysql相关系统信息函数和全局变量
6.Mysql常用函数
详细信息如下:
1.初级手工注入
DVWA登录之后设置 security level为low,找到SQL Injection之后,通过显错注入的方式来判断是否存在注入。添加单引号之后 页面显示报错如下
提示存在语法错误 ,原因在于引号没有闭合好,页说明了sql语句查询的时候是带上引号的,就自发的认为是字符型参数。在输入框中使用数字万能秘钥 1 or 1=1 的时候 竟然发现可以查询出来 。在数据库中也直接使用 查询语句 SELECT * FROM `users` where user_id = '1 or 1=1' 也可以查出。这个就有点奇怪了。原因在于如果是字符型参数,输入 1 or 1=1 ,是不能查出数据的,我一度还以为数据库进行了布尔运算,百思不得。后面发现 这个参数竟然是int型 的。数据库会自动截断输入不为数字的字符,保留从首位开始为数字的一段入参。这个也解释了为什么 输入 1 or 1=1 能够得出id =1 的信息。
既然后台语言查询的时候 是有引号的 那就先闭合引号 再注入sql语句。比如使用 1 ' or 1=1 -- ['--'后面有个空格,否则会报错],这个输入会显示出表里面的所有数据
再比如 1' or '1'= '1 这个就不需要sql注释语句来注释后面的引号;
2.order by的使用
初步显示数据之后,我们可以判断一下 这个查询语句 查询了这张表 几列数据,这时使用 order by 来判断查询了几列。order by 数字 这个语句指示这按照查询列的数据来排序,具体产生什么样的结果 我们可以看看下面的查询结果。
最简单的 SELECT `first_name`,`last_name` FROM `users` 查询
添加order by 1之后的 SELECT `first_name`,`last_name` FROM `users` order by 1的结果
发现第一列开始按照首字母进行了排序
添加order by 2之后的 SELECT `first_name`,`last_name` FROM `users` order by 2的结果
增大数字为3,发现报错
利用这个原理 我们可以一步步增大order by 数字 ,直到报错为止,这个报错意味着只查询了这么几列的。
所以在输入框中我们输入 1' order by 3 -- [--后面需要有空格,mysql的注释语法导致的],发现报错了,故数值下减,直到判断为2 结束order by 的运用。
3.union查询注意点
通过order by 我们知道了查询的列数 我们需要使用 union查询来输出我们需要的信息。使用union 的时候 我们可以使用火狐插件 如 hackbar 来方便我们操作,如下图所示,我们输入查询的列数即可
union查询有一定的特点,在http://www.w3school.com.cn/sql/sql_union.asp 这里面讲了。即union查询左右两边查询的数据类型需要相似或者一致。
这个也就意味着 我们输出的数据可以在数字所指示的地方显现出来。
有了这个之后,我们去获得一些我们想要的信息。比如user(),version(),database()等。
自然也可以这个样子
两种方式其实是一样的。
有了这些之后,我们还可以看看操作系统信息,这里就需要用到数据库的全局变量了,全局变量不需要说明在哪个库。union select 1,@@global.version_compile_os from mysql.user-- 以及union select 1,@@global.version_compile_os from 结果是一样的
后续还可以猜解表名什么的可以自己搜搜了。
可以参考http://www.2cto.com/article/201307/230064.html
4.Mysql相关的注释用法(比如 ‘--’后面需要跟一个空格或者回车等)
MySQL服务器支持3种注释风格:
从‘#’字符从行尾。
从‘-- ’序列到行尾。请注意‘-- ’(双破折号)注释风格要求第2个破折号后面至少跟一个空格符(例如空格、tab、换行符等等)。该语法与标准SQL注释语法稍有不同,后者将在1.8.5.7, “‘--’作为注释起始标记”中讨论。
从/*序列到后面的*/序列。结束序列不一定在同一行中,因此该语法允许注释跨越多行。
5.Mysql相关系统信息函数和全局变量
了解Mysql相关系统信息函数和全局变量有助于我们更好的了解这个系统
USER()、SYSTEM_USER()、SESSION_USER()、CURRENT_USER()和CURRENT_USER 这个都是对等的,schema()等于 database()。
数据库中经常出现 @@ ,这个起头的代表的就是全局变量,格式是@@global.var_name。常用的有 version version_bdb version_compile_os等 多搜集一些这样的数据是不会有错的。
这个可以参考http://www.cnblogs.com/gavin110-lgy/p/5772577.html
6.Mysql常用函数
了解这个主要适用于转换注入语句的时候,方便过安全狗这类的,可以参考http://www.2cto.com/database/201508/436118.html 。
SQL注入相关的知识【Mysql为例子】的更多相关文章
- sql注入攻防 以php+mysql为例
随着Web应用的高速发展和技术的不断成熟,对Web开发相关职位的需求量也越来越大,越来越多的人加入了Web开发的行列.但是由于程序员的水平参差不齐或是安全意识太低,很多程序员在编写代码时仅考虑了功能上 ...
- BUUCTF[归纳]sql注入相关题目
这是我自己对于sql注入的部分ctf题型的归纳,均来自buuctf的平台环境. [0CTF 2016]piapiapia 我尝试了几种payload,发现有两种情况. 第一种:Invalid user ...
- sql注入问题 java中将MySQL的数据库验证秘密加上 ' or '1'= '1 就可以出现万能密码
password的字符串中,加上 ' or '1'= '1 就可以制作出万能密码. 原因如下: 原代码中密码是123456 执行数据库查询语句 实际上执行的SQL语句是: select * from ...
- 【转载】以Java的视角来聊聊SQL注入
以Java的视角来聊聊SQL注入 原创 2017-08-08 javatiku Java面试那些事儿 在大二就接触过sql注入,之前一直在学习windows逆向技术,认为web安全以后不是自己的从业方 ...
- MySQL 及 SQL 注入
如果您通过网页获取用户输入的数据并将其插入一个MySQL数据库,那么就有可能发生SQL注入安全的问题. 本章节将为大家介绍如何防止SQL注入,并通过脚本来过滤SQL中注入的字符. 所谓SQL注入,就是 ...
- MySQL SQL 注入
如果您通过网页获取用户输入的数据并将其插入一个MySQL数据库,那么就有可能发生SQL注入安全的问题. 本博文将为大家介绍如何防止SQL注入,并通过脚本来过滤SQL中注入的字符. 所谓SQL注入,就是 ...
- 在SQL注入中利用MySQL隐形的类型转换绕过WAF检测
web应用一般采用基于表单的身份验证方式(页面雏形如下图所示),处理逻辑就是将表单中提交的用户名和密码传递到后台数据库去查询,并根据查询结果判断是否通过身份验证.对于LAMP架构的web应用而言,处理 ...
- 三十一、MySQL 及 SQL 注入
MySQL 及 SQL 注入 如果您通过网页获取用户输入的数据并将其插入一个MySQL数据库,那么就有可能发生SQL注入安全的问题. 本章节将为大家介绍如何防止SQL注入,并通过脚本来过滤SQL中注入 ...
- DB-MySql:MySQL 及 SQL 注入
ylbtech-DB-MySQL:MySQL 及 SQL 注入 1.返回顶部 1. MySQL 及 SQL 注入 如果您通过网页获取用户输入的数据并将其插入一个MySQL数据库,那么就有可能发生SQL ...
随机推荐
- 搭建typescript开发环境最详细的全过程
搭建typescript开发示例https://github.com/Microsoft/TypeScriptSamples typescript案例https://www.tslang.cn/sam ...
- ArcGIS制图表达Representation实战篇1-边界线和行道树制作
ArcGIS制图表达Representation实战篇1-边界线和行道树制作 by 李远祥 即便是有了一些制图表达的基础,很多人还是对ArcGIS制图表达理解停留在表面,因为没有实际的强化训练是很难体 ...
- JAVA中的char类型
1.JAVA中,char占2字节,16位.可在存放汉字 2.char赋值 char a='a'; //任意单个字符,加单引号. char a='中';//任意单个中文字,加单引号. char a=1 ...
- Struts2的概述和入门
忽如一夜春风来,千树万树梨花开 上节我们说到,JAVAEE的三层架构,即web层,service层,dao层.hibernate是应用在dao层的.而我们现在所学的Struts2是应用在web层.St ...
- php解析
vim /usr/local/apache/conf/httpd.conf ##修改apache的网页配置文件 → 解析php文件 /usr/local/apache/bin/apache ...
- 测试工作中ADB命令实战
作者:TT,<测试架构师>微信公众号作者 大家能点击进来,说明还是对ADB有所了解或听说过的,可能也会比较熟练的掌握了这些命令,下面描述如有不对的地方,欢迎指正和交流学习,请多指教! 一. ...
- BZOJ 3083: 遥远的国度(树链剖分+DFS序)
可以很显而易见的看出,修改就是树链剖分,而询问就是在dfs出的线段树里查询最小值,但由于这道题会修改根节点,所以在查询的时候需判断x是否为root的祖先,如果不是就直接做,是的话应该查询从1-st[y ...
- 关于RunLoop
首先我们要先认识一下这个RunLoop; NSRunLoop是Cocoa框架中的类,与之的Core Fundation 中CFRunLoopRef类. 这两者的区别是,前者不是线程安全的,而后者是线程 ...
- Linux 下文件操作 shell
删除目录下的所有文件ls *.log | xargs rm -f当前目录所有文件大小的总和ll | awk '{sum += $5}; END {print sum/1048576}'将命令推送到后台 ...
- 纯CSS3之五子棋(黑白棋)画法
无聊想用JS写个五子棋玩玩,这边先用CSS3画出了五子棋,感觉挺惊艳的.发上来看看 PS:第一次发博文T-T 此为个人原创. 不多说上图: 代码如下: <!DOCTYPE html> & ...