upload-labs-靶场(1-19关详细解答 保姆级教程)

news2025/1/11 22:54:34

Pass-01

下载 upload-labs-mster靶场 创建一个upload目录 不然无法打开upload-labs 靶场

1.我们先上传一个 php后缀文件 显示我们该文件不允许上传 只能上传 jpg png gif的文件后缀

2.我们可以上传 自己写的php 后缀改成jpg上传 然后抓包 可以看到 数据上传了 我们可以在burpsuite里修改一下后缀 改成php后缀 这样我们自己写的php就上传成功了

我们发现 我们的php文件上传成功了 

然后在上传到的图片鼠标右键新建标签页打开图片 就上传成功了 

这里记得如果的php版本是5.6.9的话 记得改成php 7.3.4 就ok了

Pass-02

查看提示看到是在服务端对数据的MIME进行检查,MIME验证就是验证文件的类型。所以我们的思路就是用burp抓包然后修改文件的类型。

1.上传一个1.php文件 使用burpsuite抓包 抓到包以后修改一下我下面这个图圈住的那个红框框里的东西 

修改完成 然后放包 成功上传 然后就上传上去我们的1.php啦

Pass-03

查看页面源代码 发现禁止上传这四种文件后缀

2.这样我们就得想办法绕过一下 在网上搜索了一下 发现这种黑名单并不严谨 在某些特定的环境下    一些特殊后缀 仍然会被当成php文件 可以在1.php后面 加 1或者2 或者3 或者4 这里我选择的是

1.php3 上传这个文件 发现直接上传成功

Pass-04

1.这里跟第一关的的第一步 一样 查看页面源代码 发现这里禁止的黑名单比第三关多了很多 

这些后缀的都无法上传 

2.这里我们就要用到传说中的.htaccess文件上传了 首先:创建htaccess文件(文件名就为htaccess)就可以  文件内容如下

AddType application/x-httpd-php .png

这里给大家讲解一下 htaccess文件是是什么:

htaccess文件是 Apache 服务器中的一个配置文件,它负责相关目录下的网页配置。 通过htaccess文件,可以帮我们实现:网页 301重定向 、自定义404错误页面、改变文件扩展名、允许/阻止特定的用户或者目录的访问、禁止目录列表、配置默认文档等功能

2.1 上面的那个代码的意思就是里面有一个后缀为.png的文件 他就会被解析成.php 先上传一个1.png文件 然后在上传htaccess文件 再访问1.png  这里你做的都很正确 但是他就是不显示

这是因为环境的问题 我们可以用fofa 空间搜索引擎 去搜索 别人的靶机 

搜索语法是 

title="upload-labs"

Pass-05

查看页面源码 发现 并没有转换大小写的代码

这样我们就可以上传大小写混合的后缀名来进行绕过。上传一个1.Php文件,直接上传成功

直接上传成功

Pass-06

查看第六关源码,对比第四关,发现没有收尾去空。

我们接下来的思路就是在文件末尾添加空格 但是由于windows会自动删除空格 我们需要用burpsuite抓包 在burp里去添加空格 

这样我们就直接上传成功了

Pass-07

查看页面源码  对比一下 上面的第四关 发现 少了一个删除文件末尾的点

跟第六关大差不差 因为windows后面不能加.会自动删除 所以我们用burpsuite抓包 在burp里添加一个点

这里我们需要注意 上面的用的都是7.几的版本 第七关需要用 5.6.29的 就可以打开了 上传成功

Pass-08

查看页面源代码  对比一下第四关的页面源码 发现 少了去除字符串 

跟上面的关卡一样 使用burpsuite抓包 在burp里添加  文件后缀名为::$DATA

上传成功

Pass-09

查看源码 不能跟之前的那些思路绕过一样  仔细看了一个代码 发现没有循环验证  就是转换大小写 

去除空格的它只验证一次 所以就可以把后缀改成.php. . 然后上传1.php 抓包修改

上传成功

Pass-10

查看第十关源码,可以看出没有了前几关的验证方式,而且是一个黑名单验证,意思是如果上传了它这些后缀的文件,就会把后缀名删除,没了后缀名也就无法正常解析

这关同样只验证一次,所以我们只需要把后缀改成两次.php文件后缀,它删除掉中间的php后后缀仍然为php

然后上传成功

Pass-11

查看这关源码,很明显是一个白名单上传,只允许上传它给定的后缀名,最主要看到就是我红色框 圈住的代码

save_path是一个可控的变量,后面还有一个后缀名需要绕过,这个时候需要使用%00截断 我们上传一个 1.png图片 然后用burp抓包 在burp抓包里修改 

修改一下 红圈框住的地方 因为环境不行 

我们可以在ctfhub里做 

完成之后就上传成功了

图片我没截图 可以去ctfhub里 做 就可以成功

Pass-12

查看页面源代码 和第十一关做一下对比 发现接受值变成了post 思路和第十一关一样  但是post方式不会自行解码 所以要对%00进行编码 如下图 

然后就上传成功了

Pass-13

这一关会读取判断上传文件的前两个字节,判断上传文件类型,并且后端会根据判断得到的文件类型重命名上传文件 使用大佬的图片🐎 跟文件包含绕过

我们上传图片马因 为是文件包含漏洞,地址加上file

然后在upload靶场下创建一个1.txt 写<?php phpinfo;?>

因为是文件漏洞然后在网址后加上file参数 就拿下了

Pass-14

跟第十三关一样的原理

打开我们的include.php文件包含 ?file= 后面加上我们的图片地址  就上传成功了

也可以用中国菜刀 如下图

Pass-15

查看源码,看到这个函数,exif_imagetype() 读取一个图像的第一个字节并检查。过程和13,14关一样

成功登陆

Pass-16

图片马中的phpinfo会被删除,但一句话木马会被留下,可以使用蚁剑连接成功.

这一关使用了二次渲染

然后跟14关最后一步一样 用菜刀连接 

就ok了

Pass-17

和查看源代码发现,当我们上传php文件后,我们的php文件会在服务器先存在一段时间,然后再被代码给删掉.所以我们的思路就是利用这一段极短的时间来进行操作.利用BP的攻击模块,不断的去访问我们要上传的文件(把我们要上传的文件的包作为我们的playload.而该php代码写一个创建文件函数来创建一个php文件,该文件的内容写我们的木马).所以我们的整体思路就是不断的上传第一个文件,然后再写一个playload放到BP的攻击模块,该playload的作用是不断的去访问我们上传的文件,即通过去把握到该文存在的那极短的时间去访问,然后执行里面的代码,从而创建我们的木马文件,一定要使用工具辅助完成,人工点击不可能,这种技术叫做文件上传竞争、

访问该php的playload

用burp里的狙击手模式不断地和文件进行竞争

可以这样去做 去突破这个关卡 但是这种情况差一点的电脑应该可能会死机 电脑会起飞的

电脑差的宝宝们 可以看教程知道怎么做了 不要去尝试哦

Pass-18

这关这里有个错误 上传的图片放不到upload下 这里进行一个小小的改动。打开18关的myupload.php

修改这里在后面加上‘/’,然后重启靶场

查看代码,发现和第17关的区别是这关检测了后缀名不能直接上传php文件 所以这关要上传图片马,其他步骤和17关类似。访问图片时使用文件包含
上传22.gif然后抓包          和17关一样的过程 使用狙击手

Pass-19

查看第19关的页面源代码 可以看到区别 多了一个保存名称 没有对上传的文件做判断,只对用户输入的文件名做判断。查看源码,有move_uploaded_file()这样一个函数,它有一个特性,会忽略到文件末尾的/.
上传一个包含php语句的jpg文件,然后保存名称为2.php./

这样就成功了

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

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

相关文章

5.缓存雪崩问题及解决思路

缓存雪崩问题及解决思路 缓存雪崩是指在同一时段大量的缓存key同时失效或者Redis服务宕机&#xff0c;导致大量请求到达数据库&#xff0c;带来巨大压力。 解决方案&#xff1a; 给不同的Key的TTL添加随机值利用Redis集群提高服务的可用性给缓存业务添加降级限流策略给业务添…

用EasyV全景图低成本重现真实场景,360°感受数字孪生

全景图&#xff0c;即借助绘画、相片、视频、三维模型等形式&#xff0c;通过广角的表现手段&#xff0c;尽可能多表现出周围的环境。避免了一般平面效果图视角单一&#xff0c;不能带来全方位视角的缺陷&#xff0c;能够全方位的展示360度球型范围内的所有景致&#xff0c;最大…

maven插件1(timer-plugin)

[https://maven.apache.org/plugin-developers/index.html(https://maven.apache.org/plugin-developers/index.html) 概述 timer plugin, 提供4个goal: currentTimecurrentDatecurrentMonthcurrentYear 打包 命令 maven clean install 常见错误 goalPrefix MISSING 错…

记录一次环境的安装

目录 新添加的代码 代码解释 为啥ubuntu用debian软件源 为啥修改sources.list.d S权限意思 php缺少和数据库连接的模块 使用root登陆数据库1698错误 字段解释 auth_socket解释 使用root登陆数据库方法 详细解释 首先在安装的时候&#xff0c;有一个dockerfile文件&a…

SpringBoot 依赖之Java Mail Sender邮件发送

Java Mail Sender 依赖名称: Java Mail Sender功能描述: Send email using Java Mail and Spring Framework’s JavaMailSender.使用 Java Mail 和 Spring Framework 的 JavaMailSender 发送电子邮件。 <dependency><groupId>org.springframework.boot</group…

机器学习模型选择与优化: 打造智能IDS

引言 面对琳琅满目的机器学习模型&#xff0c;你是否也感到无从下手&#xff1f;别担心&#xff0c;这篇文章将为你详细讲解各种模型的优缺点&#xff0c;帮助你选择最适合的模型&#xff0c;并进行优化。是时候给你的入侵检测系统装上最强“大脑”了! 机器学习模型概述 监…

java2~~~

类变量 [修饰符] class 类{[其他修饰符] static 数据类型 变量名; } static 用来修饰的结构&#xff1a;属性、方法; 代码块、内部类&#xff1b;&#xff08;构造器不能够用static修饰&#xff09;当类被加载进内存时&#xff0c;静态成员变量随着类一起进入方法区&#xff…

VMware安装Win10系统(保姆级教程)

需要自己先下载并安装VMware 和Win10系统镜像&#xff1a; VMware官网&#xff1a;VMware - Delivering a Digital Foundation For Businesses Win10下载地址&#xff1a;MSDN,我告诉你 1.新建虚拟机设置 2.启动Win10虚拟机设置 注意&#xff1a; 当出现有字体的时候&#…

“论云原生架构及其应用”写作框架软考高级论文系统架构设计师论文

论文真题 近年来&#xff0c;随着数字化转型不断深入&#xff0c;科技创新与业务发展不断融合&#xff0c;各行各业正在从大工业时代的固化范式进化成面向创新型组织与灵活型业务的崭新模式。在这一背景下&#xff0c;以容器和微服务架构为代表的云原生技术作为云计算服务的新…

行为验证码——错误代码解释

错误代码 前端请求展示错误代码 前端验证错误代码 后端验签错误代码 内容素材的地址:https://www.kgcaptcha.com/docs?vid56&namecwdm

【.NET 8 实战--孢子记账--从单体到微服务】--编写服务端框架

框架是一个项目所必须的&#xff0c;是一组预先编写的代码库和工具&#xff0c;提供了一个可以复用的结构&#xff0c;以帮助开发者快速构建应用程。即使项目目前是一个单体应用&#xff0c;我们还是需要先设计框架的&#xff0c;但是我们不可能在项目的初期就编写出一个完美的…

C语言例题(图形打印,逆序输出,交换数组,平均值)

一.X形图形 多组输入&#xff0c;一个整数&#xff08;2~20&#xff09;&#xff0c;表示输出的行数&#xff0c;也表示组成“X”的反斜线和正斜线的长度。针对每行输入&#xff0c;输出用“*”组成的X形图案。 代码展示 #include <stdio.h> int main() {int i0;int j…

鸿蒙对接极光推送时候报错1000900010,厂商token获取失败

在AppGallery Connect上配置项目的调试证书&#xff0c;然后手动导入&#xff0c;不要用IDE的自动构建证书&#xff1a; https://developer.huawei.com/consumer/cn/service/josp/agc/index.html#/

大模型简介以及该如何学习的路线

人人都看得懂的大模型简介 大模型就像一座庞大的图书馆&#xff0c;里面有非常多的书籍。但与普通图书馆不同的是&#xff0c;这座图书馆中的每本书都是关于不同事物的描述和知识。而这些书籍中的每一页都代表了这个事物的一些特征或细节。现在&#xff0c;想象一下&#xff0c…

KVM高级功能部署

kvm虚拟机迁移 静态迁移(拷贝) 关闭虚拟机 拷贝 磁盘镜像 .xml配置文件 操作方便 动态迁移 动态迁移分为基于共享存储的动态迁移和基于数据块的动态迁移 基于共享存储的动态迁移 利用共享存储,存磁盘镜像,存配置文件速度快不用关虚拟机 基于数据块…

OCCT使用指南:Foundation Classes

1、介绍 本手册解释了如何使用Open CASCADE Technology (OCCT) Foundation Classes。它提供了关于基础类的基础文档。有关基础类及其应用的高级信息&#xff0c;请参阅我们的电子学习和培训产品。 基础类提供各种通用服务&#xff0c;如自动动态内存管理&#xff08;通过句柄操…

抖店到家外卖重新布局,本地生活服务商创业机遇再现

自抖音平台去年推出团购、外卖、小时达等即时零售业务以来&#xff0c;这一举措不仅重塑了本地生活服务领域的竞争格局&#xff0c;也为众多拥有线下门店的商家开辟了全新的增长路径。众多商家敏锐捕捉到了这一市场机遇&#xff0c;纷纷入驻短视频平台&#xff0c;利用平台的强…

c基础 函数

函数 1.函数基本用法 1.1定义和三要素 函数是一个完成特定功能的代码模块&#xff0c;其程序代码独立&#xff0c;通常要求有返回值&#xff0c;也可以是空值。 三要素&#xff1a;功能 参数 返回值 参数&#xff1a;参数就是在函数声明时和函数调用时定义的变量。它用于传递…

钟氏崛起的奥秘:归隐与清议

话题的主角是钟皓&#xff0c;东汉后期人&#xff0c;颍川钟氏的第十代。他官做的不大&#xff0c;最高职务是一个小县的县长&#xff08;俸禄400石&#xff09;&#xff0c;远远没有父、祖辈高&#xff0c;父亲做到了光禄大夫、太守&#xff08;2000石&#xff09;。然而&…

【数据结构与算法】详解计数排序:小范围整数排序的最佳选择

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;《数据结构与算法》 期待您的关注 ​ 目录 一、引言 二、计数排序的基本原理 三、实现步骤 1. 确定数据范围 2. 初始化计数数组…