SUCTF2019 web部分赛题复盘

CheckIn

一道文件上传的题目,首先尝试上传最简单的一句话木马shell.php
SUCTF2019 web部分赛题复盘_第1张图片
后缀被检测,尝试上传一个txt文件
SUCTF2019 web部分赛题复盘_第2张图片
在php手册中查找一下exif_imagetype函数
SUCTF2019 web部分赛题复盘_第3张图片
也就是说他会检测我们上传文件的签名。
我们在上传包含最简单的一句话木马的图片马,提示被检测,修改一句话木马为进行上传
SUCTF2019 web部分赛题复盘_第4张图片
错误码为405,方法不被允许,也就是说我们上传的图片马没有被成功解析,考虑上传.user.ini或者.htaccess进行文件上传。

.user.ini实际上就是一个可以由用户“自定义”的php.ini,我们能够自定义的设置是模式为“PHP_INI_PERDIR 、 PHP_INI_USER”的设置。

我们在.user.ini当中写入内容为

auto_prepend_file=shell.jpg

起到的作用类似于在每一个php文件前require('shell.jpg'),也就是起到了一个了文件包含的作用
抓包修改文件头后进行上传,jpg图像的标识头ff d8 ff e0 00 10 4a 46 49 46 00 01
在这里插入图片描述上传成功后也就是说明我们的index.php包含了我们上传一句话木马的图片,也就可以利用图片中的一句话木马进行getshell
SUCTF2019 web部分赛题复盘_第5张图片

easy_sql

由官方wp的解释来看,这道题目需要我们去对后端语句进行猜测,有点矛盾的地方在于其描述的功能和实际的功能似乎并不相符,通过输入非零数字得到的回显1和输入其余字符得不到回显来判断出内部的查询语句可能存在有||,也就是select 输入的数据||内置的一个列名 from 表名,进一步进行猜测即为select post进去的数据||flag from Flag(含有数据的表名,通过堆叠注入可知),需要注意的是,此时的||起到的作用是or的作用。

解法1

输入的内容为*,1
内置的sql语句为$sql = "select ".$post['query']."||flag from Flag";
如果$post['query']的数据为*,1,sql语句就变成了select *,2||flag from Flag,也就是select *,1 from Flag,也就是直接查询出了Flag表中的所有内容

解法2

输入的内容为1;set sql_mode=pipes_as_concat;select 1
其中set sql_mode=pipes_as_concat;的作用为将||的作用由or变为拼接字符串,这是我在本地做的测试,我们执行的语句分别为select 1和set sql_mode=pipes_as_concat和select 1||flag from Flag,读出flag
SUCTF2019 web部分赛题复盘_第6张图片

EasyWeb

首先是一个正则表达式

if ( preg_match('/[\x00- 0-9A-Za-z\'"\`~_&.,|=[\x7F]+/i', $hhh) )
    die('Try something else!');

检测一下还有什么可用字符

?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ ";
for($i=0;$i<95;$i++){
	if ( preg_match('/[\x00- 0-9A-Za-z\'"\`~_&.,|=[\x7F]+/i', $content[$i] )){
		echo " ";
	}
	else{
		echo $content[$i];
	}
}
?>

SUCTF2019 web部分赛题复盘_第7张图片
当时做到这里就有点麻瓜了,做过类似的不使用数字和字母命令执行的题目,但限制长度为18导致很多复杂的构造无法完成,这里用到的关键符号就是^,用到的方法是利用不可见字符的异或来构造_GET对函数进行调用,首先是获取_GET的ascii码值
SUCTF2019 web部分赛题复盘_第8张图片
然后使用0xff分别对这几个字符进行异或操作
SUCTF2019 web部分赛题复盘_第9张图片
得到了0xa0b8baab(均为不可见字符),将其与0xffffffff进行异或操作,最后的payload为

?_=${%ff%ff%ff%ff^%a0%b8%ba%ab}{%ff}();&%ff=phpinfo

文件上传的界面采用了exif_imagetype的校验方式
在文件头加上\x00\x00\x8a\x39\x8a\x39对校验进行绕过,先上传.htaccess文件,内容为

AddType application/x-httpd-php .cc
php_value auto_append_file "php://filter/convert.base64-decode/resource=shell.cc"

第一句的解释为将.cc后缀的文件作为php解析
第二句话的解释为
SUCTF2019 web部分赛题复盘_第10张图片
也就是upload目录下的文件都会自动包含php://filter/convert.base64-decode/resource=shell.cc的内容,之所以这么写是因为我们无法在该php版本使用

你可能感兴趣的:(SUCTF)