data:image/s3,"s3://crabby-images/b08a1/b08a122f2b1d37fc5d59076e726dde6aa0cde00f" alt=""
来自之前cnblog的博客
源地址:https://www.cnblogs.com/This-is-Y/p/14257025.html
use information_schema;
show tables;
可以看到很多表
data:image/s3,"s3://crabby-images/61f55/61f55dc2525e9e256432e8c69dbf4168ff8ac54e" alt=""
在注入的时候,有用的表是tables,columns
这两个表存了整个mysql数据库中的表的信息,列的信息
看一下两个表中的信息
TABLES:
data:image/s3,"s3://crabby-images/03b44/03b440f06684416f663d0ff3758db6d1c9759634" alt=""
在注入过程中只需要关注两条,table_name 和table_schema,table_name是所有表的表名,table_schema是数据库的名字,
比如在jsp表下有很多表
data:image/s3,"s3://crabby-images/55d33/55d334f57f2ec318e7bbeff8395d4c25907b8165" alt=""
查找tables表中,当table_schema=jsp时的table_name,可以看到和use jsp;show tables;指令执行的结果一致
通俗的说法就是 看看jsp数据库下面有哪些数据表
或者反过来查, select table_schema from information_schema.tables where table_name=”c_programming”;
查找当table_name=“c_programming”时,有哪些数据库,通俗点说就是,看看哪些数据库下面有一个叫做“c_programming”的数据表。
data:image/s3,"s3://crabby-images/5ca2c/5ca2ce8be8dd93bafcc1a47a9dda2ceaf527beb9" alt=""
COLUMNS:
这个视图下也有table_schema,table_name,还有一个column_name
可以看一下column_name,举个例子,看一下jsp表下的c_programming的信息
data:image/s3,"s3://crabby-images/222c9/222c9f49014535df84e54f752dec529275f532e7" alt=""
列名分别为number,content,a,b…………
执行select column_name from information_schema.columns where table_schema=”jsp” and table_name=”c_programming”;
这个是查看 jsp库下c_programming表的字段信息,
data:image/s3,"s3://crabby-images/55d2e/55d2e11d4277b389580f485c9583e10bdf483a7a" alt=""
一致
所以可以直接用information_schema.colums表,重点为其中的table_name,column_name,table_schema几个字段,可以很快的得到需要的信息
之后是concat和group_concat
concat可以把字段拼接起来,group_concat可以把每一条数据拼接起来(前提是知道字段名)
首先看一个表:
data:image/s3,"s3://crabby-images/aeece/aeece0cff8f23d31fd9fefcf0add481bfbc25006" alt=""
select concat(username,password) from admin.admin;
data:image/s3,"s3://crabby-images/7c543/7c5431132d39e36ab1cad631c10d483634695ae5" alt=""
或者是加点其他的字符,方便区分 select concat(username,” + “,password) from admin.admin;
data:image/s3,"s3://crabby-images/b84b1/b84b1559e9323ee0b97c7e4aa0f319f60a015dd3" alt=""
select group_concat(username,” + “,password) from admin.admin;
data:image/s3,"s3://crabby-images/8d235/8d2358e29e31510531afe7725a9fa7b58a2b06b9" alt=""
group_concat也可以加点东西区分,默认是一个”,”,在group_concat()里加一个separator参数(不要逗号)
举个栗子:select group_concat(username,” + “,password separator ‘;’) from admin.admin;
data:image/s3,"s3://crabby-images/1c657/1c6576607885c0e1474804e336be8f8e0d5e96f9" alt=""
然后来尝试用information_schema来获取admin所有的信息,
1、
select database();确认数据库名
select version();确认mysql版本
2、
select distinct table_schema from information_schema.columns;查看所有的库名,实战中估计会要用到group_concat
data:image/s3,"s3://crabby-images/cf301/cf301bbbabc8357c4ebec8b3cfc6591cc159d8d6" alt=""
select group_concat(distinct table_schema) from information_schema.columns;
3、
select group_concat(distinct table_name) from information_schema.columns where table_schema=”admin”; 查看该库下的表
data:image/s3,"s3://crabby-images/b5139/b5139f9c02fc6d7a614f591b1dab4a92a71c2ce5" alt=""
select group_concat(distinct table_name) from information_schema.columns where table_schema=”security”;
data:image/s3,"s3://crabby-images/5d88d/5d88d92e03af65eccf2dae6d2ba904888118ed3f" alt=""
4、
select group_concat(column_name) from information_schema.columns where table_schema=”security” and table_name=”users”;查看该表的字段名
data:image/s3,"s3://crabby-images/09c94/09c94d1a1e21d5f49cb6e33f9c216b23cecd8dbd" alt=""
select group_concat(column_name) from information_schema.columns where table_schema=”admin” and table_name=”admin”;
data:image/s3,"s3://crabby-images/e8927/e892758c80e8b42efa5fddd75be638791cb3a30c" alt=""
5、
select group_concat(id,” = “,username,” = “,password separator “\n”) from security.users;爆数据
data:image/s3,"s3://crabby-images/3b482/3b482c14cd9fc9e033169be43d512f60b9dac872" alt=""
select group_concat(username,” = “,password separator “\n”) from admin.admin;
data:image/s3,"s3://crabby-images/acac5/acac5a3b1242957dd44da098902eddcf74c30a6f" alt=""
c_programming