ctf.show web 9-12 writeup

ctf.show web 9-12 writeup

目录

web9

解题过程

web10

解题过程

 防护一:

防护二:

防护三:

两个小知识:

group by

with rollup

web11

解题过程

删除session中的password

web12

解题过程


web9

题目:ctf.show平台上的

ctf.show web 9-12 writeup_第1张图片

解题过程

 打开是个登录界面,没什么头绪

ctf.show web 9-12 writeup_第2张图片

在index.phps中,源码泄露

10){
			die("password error");
		}
		$sql="select * from user where username ='admin' and password ='".md5($password,true)."'";
		$result=mysqli_query($con,$sql);
			if(mysqli_num_rows($result)>0){
					while($row=mysqli_fetch_assoc($result)){
						 echo "登陆成功
"; echo $flag; } } ?>

 看到md5($password,true),想起了之前做的一道题目,也是这个知识点。

将password的值定为ffifdyop,登录,得到flag.

ctf.show web 9-12 writeup_第3张图片

原因如下:

  1. content: ffifdyop

  2. hex: 276f722736c95d99e921722cf9ed621c

  3. raw: 'or'6\xc9]\x99\xe9!r,\xf9\xedb\x1c

  4. string: 'or'6]!r,b

  5. 在mysql里面,在用作布尔型判断时,以1开头的字符串会被当做整型数。要注意的是这种情况是必须要有单引号括起来的,比如password=‘xxx’ or ‘1xxxxxxxxx’,那么就相当于password=‘xxx’ or 1  ,也就相当于password=‘xxx’ or true,所以返回值就是true。当然在我后来测试中发现,不只是1开头,只要是数字开头都是可以的。

ffifdyop的原始二进制字段中含有'or'6\xc9]\x99\xe9!r,\xf9\xedb\x1c, 恰构成了SQL注入漏洞,password=‘xxx’ or 1,那么返回值也是true。(xxx指代任意字符)

详细解释传送门

 

web10

题目:

ctf.show web 9-12 writeup_第4张图片

解题过程

打开题目

ctf.show web 9-12 writeup_第5张图片

类似于刚才的题目,继续探查一下index.phps,源码泄露,如下

0){
					while($row=mysqli_fetch_assoc($result)){
						if($password==$row['password']){
							echo "登陆成功
"; echo $flag; } } } ?>

 防护一:

我们可以看到,过滤了相当多的关键字符,但是因为替换的是空,所以当时想的是还能够双写绕过

function replaceSpecialChar($strParam){
             $regex = "/(select|from|where|join|sleep|and|\s|union|,)/i";
             return preg_replace($regex,"",$strParam);
        }

php使用replaceSpecialChar一次性替换所有指定字符文本,下面网上的实例



//结果:*****3*33*34*

防护二:

但是,这段代码直接阻断了双写绕过,如果双写的话,字符串中关键词会被替换为空,这样的话替换前后的字符串长度不同。不太行。。。

if(strlen($username)!=strlen(replaceSpecialChar($username))){
			die("sql inject error");
		}
		if(strlen($password)!=strlen(replaceSpecialChar($password))){
			die("sql inject error");
		}

防护三:

if($password==$row['password'])
{
    echo "登陆成功
"; echo $flag; }

两个小知识:

创建一个名为users的表,里面有如下数据

ctf.show web 9-12 writeup_第6张图片

group by

sql语句:   select id from users;

ctf.show web 9-12 writeup_第7张图片

sql语句:select id,count(*) from users group by id;

ctf.show web 9-12 writeup_第8张图片

with rollup

sql语句:select id,count(*) form users group by id with rollup;

ctf.show web 9-12 writeup_第9张图片

我们看到增加了一列,其中id为NULL,count(*)为统计和。

因为增加的一列id为NULL,同时我们可以对应到绕过防护三同时没有与防护一和防护二矛盾,我们传入password为空,这样的话空==空,$password==$row['password']成立!

payload:

username=admin'/**/or/**/1=1/**/group/**/by/**/password/**/with/**/rollup#&password=

ctf.show web 9-12 writeup_第10张图片

web11

题目:

ctf.show web 9-12 writeup_第11张图片

解题过程

打开题目后

ctf.show web 9-12 writeup_第12张图片

我们看到有两层防护

防护一,过滤了多个关键,如果有关键字出现会进行用空替换,并且替换前后字符串长度不同会导致错误;

防护二,传入的$password需要和session中的password相同。

因为session中的password在存储在本地,我们可以对它进行删除,这样我们传入空,空=空,即可绕过。

删除session中的password

火狐浏览器如下

ctf.show web 9-12 writeup_第13张图片

再将password输入框中字符清空,登录,即可得到flag

ctf.show web 9-12 writeup_第14张图片

web12

ctf.show web 9-12 writeup_第15张图片

解题过程

打开题目后

ctf.show web 9-12 writeup_第16张图片

在f12中发现

猜测是命令执行漏洞

首先高亮显示源码,成功!

?cmd=highlight_file('index.php');

ctf.show web 9-12 writeup_第17张图片

接下来找flag文件

print_r() 函数用于打印变量,以更容易理解的形式展示。

PHP glob() 函数

定义和用法

glob() 函数返回一个包含匹配指定模式的文件名或目录的数组。

该函数返回一个包含有匹配文件/目录的数组。如果失败则返回 FALSE。

 借一下菜鸟教程的例子:

ctf.show web 9-12 writeup_第18张图片

?cmd=print_r(glob("*"));

flag应该在名字比较长的文件中

?cmd=highlight_file('903c00105c0141fd37ff47697e916e53616e33a72fb3774ab213b3e2a732f56f.php');

ctf.show web 9-12 writeup_第19张图片


总结:

1.源码泄露:index.phps,之前碰到比较多的是index.php.bak,www.zip等。

2.group by 和 with rollup  的联合操作。

3.glob()函数,查看文件或目录。

因为buu平台炸了来ctfshow刷题,学到了好多,感谢ctfshow。

菜鸡的进阶之路遥远且艰难,冲呀!!!

 

 

你可能感兴趣的:(CTF刷题记录,web,安全)