文件上传漏洞--之upload-labs靶场第 11-15关(后三关需要制作图片马)持续更新ing...

news2025/1/12 9:02:49

第11关

第一步:查看源码

这是一个白名单,里面限制了只可以提供它所规定文件jpg,png,gif。

005ba8ba6336416c8ede2ebeb92da48b.png

 

这段 PHP 代码主要实现了文件上传的功能,并进行了一些条件判断和处理:

 

首先,定义了两个变量 $is_upload 并初始化为 false ,$msg 初始化为 null 。

 

然后,检查是否通过 POST 方法提交了表单中的 submit 按钮。

 

接着,定义了一个允许上传的文件扩展名数组 $ext_arr ,包含 jpg 、 png 和 gif 。

 

获取上传文件的扩展名,并使用 in_array 函数检查扩展名是否在允许的数组中。

 

如果扩展名合法:

 
  • 获取临时文件的路径 $temp_file 。
  • 生成保存文件的路径 $img_path ,路径包括通过 $_GET['save_path'] 获取的保存位置、随机数、当前时间和文件扩展名。
  • 如果文件移动成功(使用 move_uploaded_file 函数),将 $is_upload 设为 true ;否则,将 $msg 设为 '上传失败!' 。
 

如果扩展名不合法,将 $msg 设为 '只允许上传.jpg|.png|.gif 类型文件!' 。

 

例如,如果用户上传了一个扩展名为 jpg 的文件,并且文件移动成功,那么 $is_upload 会变为 true ,表示上传成功。如果用户上传了一个扩展名为 pdf 的文件,那么 $msg 会被设置为 '只允许上传.jpg|.png|.gif 类型文件!' ,提示用户上传的文件类型不被允许。

 由代码可以得知,文件的路径是可控的,所以save_path是一个可控的变量,后面还有一个后缀名需要绕过,这个时候需要使用%00截断。

第二步:修改php版本,和修改php配置文件内容

修改php版本

9f0ebc653499490989014f3c793df90a.png

修改配置文件内容

dc82c30091d7433f9a31a00e1691ca30.png

修改内容为如图magic_quote_gpc = Off

947dc41b83ea4088be7f253b0d6f5458.png

第三步:burpsuite抓包修改文件路径

ebee1662f5dd4705a59067bf0af2aef0.png第四步:查看访问上传的文件即可

5258e74174934439a49c836432089038.png

 第12关:

第一步:查看源码

看着和第11关差不多,但是这里换成了post

643849692d4a4a418b977e0060eb305d.png第二步:抓包看一下

思路就和第十一关一样,但是post方式不会自行解码,所以要对%00进行urldecode编码。

选中%00右键Convert selection进行url编码后放包。

362d64378a664e3e971cf952c3f1430b.png第三步:查看访问muma.php文件

fa1ef67d7fb24bd3b0fc246eafe83b57.png

第13关:

制作图片马的四种方法详解:https://www.cnblogs.com/Linkas/p/15101706.html

第一步:查看源码

bb738e4b2b654371a8470b8bb13e72cc.png

第二步:上传图片马

首先,上传一个png图片,在该png图片当中写入我们的php代码,上传成功后,使用文件包含漏洞去调用即可,

别忘了把引用文件的地址写对.其他类型的图片均可以按照此模式进行

需要有一个include.php配合使用

将include.php放在www\upload-labs目录下

include的 内容如下

 <?php
/*
本页面存在文件包含漏洞,用于测试图片马是否能正常运行!
*/
header("Content-Type:text/html;charset=utf-8");
$file = $_GET['file'];
if(isset($file)){
    include $file;
}else{
    show_source(__file__);
}
?> 

第三步:查看访问、成功  例如:http://192.168.1.10/upload-labs/include.php?file=upload/1220240728232019.gif

053f37da55f2480ca2d64316116dff73.png

 第14关:

第一步:查看源码

关键函数是getimagesize

86ed414896cb449981c2df9e80412629.png

第二步:修改图片马的内容

getimagesize函数会对目标的十六进制的前几个字符串进行读取。比如GIF的文件头问GIF89a,png的文件头为塒NG。所以这关和第十三关一样,我们只需要用notepad打开图片马,在前面加上GIF89A,保存为22.gif

1699d3d6369646eb8c0be73cf3943a1e.png

 第三步:访问地址,例如我的是

http://192.168.1.10/upload-labs/include.php?file=upload/9520240728233114.gif

ff9014936c4941379e1cd3acf46f043f.png

第15关:

第一步 :查看源码

第二步:开启 PHP 的 exif 扩展

要开启 PHP 的 exif 扩展,需要对 PHP 的配置文件(php.ini)进行相应的修改。以下是在 Linux 服务器上开启 exif 扩展的一般步骤:

 

  1. 找到 PHP 的配置文件,通常在/etc/php/7.x/apache2/php.ini或者/etc/php/7.x/cli/php.ini中(其中7.x表示 PHP 的具体版本号,你需要根据实际情况进行调整)。

  2. 打开配置文件后,搜索关键词exif,找到以下行:

    ;extension=exif

  3. 去掉前面的分号,将其改为:

    extension=exif

82ba4dab7c1d4216a6b7e10ca57963fb.png

  1. 同时,确保满足 exif 扩展的依赖条件。通常需要启用php_mbstring.dll扩展,并且确保它在php_exif.dll之前被加载。如果php.ini文件中php_mbstring.dll扩展被注释掉(前面有分号),则去掉分号。另外,建议将包含php_mbstring.dll的行移动到extension=php_exif.dll之前。例如:

    extension=php_mbstring.dll
    extension=php_exif.dll

e2a91d2e439f4e9f89521018a33b1a2e.png

  1. 保存修改后的 php.ini 文件。

  2. 最后,重启 apache 服务器或者 php-fpm 服务,以使配置生效。

完成上述步骤后,就成功开启了 PHP 的 exif 扩展。

第三步:访问地址,例如我的是

http://192.168.1.10/upload-labs/include.php?file=upload/2920240728234554.gif

b89eb25f3e214130be9ce446b5bb8b66.png

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1964284.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

GitHub Pages上用vue搭建个人网站简记

新建仓库 将仓库取名为:<你的用户名>.github.io 就像这样 GitHub会帮你自动部署在 https://jerryqjr.github.io/ 上 npm run build后把disk传入新的分支 git subtree push --prefix dist origin gh-pages将子目录 dist 的内容推送到远程分支 gh-pages 随后在 Settin…

综合点评!史上最强开源大模型Llama 3.1

在人工智能领域&#xff0c;开源模型一直是推动技术进步和创新的重要力量。 北美时间7月23日&#xff0c;Meta公司&#xff08;原Facebook&#xff09;宣布了一项重大突破&#xff1a;开源模型Llama 3.1的正式发布。这一举措预示着AI技术的又一次飞跃&#xff0c;Llama 3.1有望…

java~反射

反射 使用的前提条件&#xff1a;必须先得到代表的字节码的Class&#xff0c;Class类用于表示.class文件&#xff08;字节码&#xff09; 原理图 加载完类后&#xff0c;在堆中就产生了一个Class类型的对象&#xff08;一个类只有一个Class对象&#xff09;&#xff0c;这个对…

IOday4

一、思维导图 二、练习 1、使用父子进程完成两个文件的拷贝&#xff0c;父进程拷贝前一半内容&#xff0c;子进程拷贝后一半内容&#xff0c;子进程结束后退出&#xff0c;父进程回收子进程的资源 #include<myhead.h> int main(int argc, const char *argv[]) {//判断终…

分享:Vue3中如何使用echarts工具开发可视化图表

官方链接 点此进入 导入 import * as echarts from echarts 页面 <div id vdrBarChart style"height: 300px;width: 500px;"></div> 调用 //DOM 更新完成后&#xff0c;延时100ms执行setBarChart方法this.$nextTick(() > {setTimeout(() >…

电路设计-基础2-电阻电容

电路设计-基础2-电阻电容 分立元件常见的分立元件及其功能分立元件的特点 电阻**注意**电阻种类1. 直插电阻&#xff08;色环电阻&#xff09;2. 贴片电阻&#xff08;SMD电阻&#xff09;3. 电位器&#xff08;可变电阻器,滑动变阻器&#xff09;4. 热敏电阻&#xff08;NTC/P…

如何解决部分设备分辨率不适配

1&#xff09;如何解决部分设备分辨率不适配 2&#xff09;Unity中如何实现草的LOD 3&#xff09;使用了Play Asset Delivery提交版本被Google报错 4&#xff09;如何计算弧线弹道的落地位置 这是第396篇UWA技术知识分享的推送&#xff0c;精选了UWA社区的热门话题&#xff0c;…

运筹说 第120期 | 确定型存储模型

上一期我们一起学习了存储问题及其基本概念&#xff0c;本期小编将带大家学习确定型存储模型的相关内容。 下面我们一起来学习确定型存储模型的五个基础模型吧&#xff01; 模型一&#xff1a;不允许缺货&#xff0c;补充时间极短 为了便于描述和分析&#xff0c;对模型作如下…

基于视觉的语义匹配见多了,那基于雷达的呢?

论文题目&#xff1a; LiDAR-based HD Map Localization using Semantic Generalized ICP with Road Marking Detection 论文作者&#xff1a; Yansong Gong, Xinglian Zhang, Jingyi Feng, Xiao He and Dan Zhang 作者单位&#xff1a;北京驭势科技有限公司 导读&#xff…

【C++哈希应用】模拟实现STL中的unordered_map和unordered_set

目录 &#x1f680; 前言一&#xff1a; &#x1f525; 哈希表的改造1.1 模板参数列表的改造1.2 增加迭代器操作 二&#xff1a; &#x1f525; 封装unordered_map和unordered_set 2.1 unordered_map的模拟实现&#xff1a;2.1.1 unordered_map的测试 2.2 unordered_set的模拟实…

图像自定义画框box标注,坐标像素点获取;通过坐标点画框

1、jupyter-bbox-widget画框&#xff0c;这只能jupyter环境插件使用 pip install jupyter_bbox_widget ##安装 ##注册 jupyter nbextension enable --py --sys-prefix jupyter_bbox_widget使用 from jupyter_bbox_widget import BBoxWidget widget BBoxWidget(imagefruit.jp…

【深度学习】kaggle使用

https://blog.csdn.net/2301_78630677/article/details/133834096 https://blog.csdn.net/xiaojia1001/article/details/139467176 https://www.kaggle.com/ 使用要挂代理&#xff0c;要不然可能无法注册 绑定手机号之后才能使用GPU 每周30h免费GPU使用时长 上传数据集 Ad…

【文件解析漏洞】

使用windows2003sever服务器 第一个&#xff1a;目录解析 1、打开网站目录&#xff0c;右键打开资源管理器 新建一个1.asp文件 在1.asp目录下新建一个2.txt&#xff0c;输入asp的语句 2、使用本机访问windows2003的IP地址 访问http://192.168.189.155/1.asp/2.txt即可 第…

Minio多主机分布式 docker-compose 集群部署

参考 docker-compose搭建多主机分布式minio - 会bk的鱼 - 博客园 (cnblogs.com) 【运维】docker-compose安装minio集群-CSDN博客 Minio 是个基于 Golang 编写的开源对象存储套件&#xff0c;虽然轻量&#xff0c;却拥有着不错的性能 中文地址&#xff1a;MinIO | 用于AI的S3 …

CDP问卷调查

在数字化时代&#xff0c;CDP&#xff08;Customer Data Platform&#xff0c;客户数据平台&#xff09;作为连接企业与客户数据的关键桥梁&#xff0c;正逐渐成为企业营销策略中不可或缺的一环。为了更深入地理解CDP在企业中的应用现状、挑战与未来趋势&#xff0c;我们精心设…

A股探底强势反攻,量价齐声太漂亮

今天的A股探底回升&#xff0c;太阳线反攻&#xff0c;太漂亮了&#xff01;具体原因是这样的&#xff0c;盘面上出现2个重要变化&#xff0c;一起来看看&#xff1a; 1、今天两市低开高走&#xff0c;证券、人形机器人等板块掀起涨停潮&#xff0c;究竟是昙花一现还是有望迎来…

VMware虚拟机安装及虚拟机下安装ubuntu(附安装包)

VMware虚拟机安装及虚拟机下安装ubuntu 0 前期准备1 VMware安装2 VMware虚拟机下安装ubuntu2.1 配置虚拟机2.2 安装虚拟机ubuntu 3 在虚拟机中卸载Ubuntu参考 0 前期准备 1、VMware Wworkstation Pro安装包下载 官网-添加链接描述 百度网盘分享&#xff1a; 链接: VMware 提取…

【ThingsBoard初体验】本地编译踩坑记录

前言 这只是我自己的踩坑记录&#xff0c;以尽快启动项目为主&#xff0c;暂时不对编译出现的问题做深入分析。 第一次接触物联网项目&#xff0c;对于文章出现的问题&#xff0c;如果能帮到其他小伙伴&#xff0c;那是我的荣幸。 大佬们有更好的解决办法&#xff0c;也希望能够…

TypeError: Components is not a function

Vue中按需引入Element-plus时&#xff0c;报错TypeError: Components is not a function。 1、参考Element-plus官方文档 安装unplugin-vue-components 和 unplugin-auto-import这两款插件 2、然后需要在vue.config.js中配置webPack打包plugin配置 3、重新启动项目会报错 T…

消息中间件分享

消息中间件分享 1 为什么使用消息队列2 消息队列有什么缺点3 如何保证消息队列的高可用4 如何处理消息丢失的问题?5 如何保证消息的顺序性1 为什么使用消息队列 解耦、异步、削峰 解耦 不使用中间件的场景 使用中间件的场景 异步 不使用中间件 使用中间件 削峰 不使…