WEB应用(十四)---文件上传

news2024/11/13 10:06:16

什么是文件上传漏洞

文件上传是Web应用的常见功能,允许用户上传图片、视频及其他文件类型文件。如果用户上传的是木马文件,则服务器就会收到攻击。

对于这个漏洞的练习有一个专门的靶场,即upload-labs,这个的安装可以在windows中使用phpstudy,linux中使用docker,当然使用phpstudy更加方便快捷,使用docker会比较麻烦,如果有需要的话,你们私信我,人多的话,我可以教大家使用docker安装,并且安装后的配置怎么改等问题。windows中安装很简单

upload-labs下载地址https://github.com/c0ny1/upload-labs,访问会有点慢,挂个梯子就行,没有的话会多等一会
 

 下载好后,解压到www目录下,就可以访问了,这时候先打开第一关,随便上传一张图片,这个时候会报错,打开你的upload-labs文件夹,进去创建一个文件夹并改名upload就行,当你再次上传并显示时,就着调了

这点很重要,在下面的练习中,我会展示一到俩方法,供大家学习,其他的方法就靠你们的了

再随便找一张图片,写一个测试脚本mu.php

<?php
eval("phpinfo();");
?>

接下来就是打怪升级!

Pass-01

刚才我们可以看到已经是可以正常上传图片了,接下来我们去上传我们的测试文件,发现了弹窗,这说明什么,说明该限制是在前端完成的,那就很简单了

F12,选中我们提交的元素,看代码,发现,点击上传后,调用了一个函数,看函数名就可以知道,该函数就是来检查文件名的,我们把他删掉,上传成功,发现该显示图片的地方没有显示图片,我们本来上传的也不是图片,但是我们上传的代码是有查看php和其他的信息的作用的,现在没有显示,不要急,我们把那张没有显示的图片拖到浏览器显示窗口的位置试试

 每一次做完,都去删除一次文件

第二种方法

依然是F12这一次我们打开控制台,通过修改JS代码来上传文件,使用dom的这个方法,这个方法是将选中的元素成为一个数组,这里只有一个form表单,所以就是0,使得onsubmit内容为空,同样上传成功

Pass-02

 上传测试文件,发现这会就是后端进行校验了,我们点一下提示,提示说后端进行检查了mime,那么什么是mime呢

通过查找发现就是一种校验文件的方式,我们再来抓包看看,先上传一张图片

 

这个就是后端检查的内容   image/jpeg,上传我们的测试文件

 

将这里替换成上面的信息,放行,上传成功

 

Pass-03

我们先来看看提示,这里说禁止了这些文件后缀名,这里有一个隐藏的小知识,php文件的后缀名有很多phtml,php3,phps等,所以我们去修改文件的后缀名,就可以上传成功,虽然可以上传,但是,不一定可以执行,要想执行,就需要我们去修改Apache的配置文件。

在这里添加AddType application/x-httpd-php .php .phtml .phps .php3 ,重启Apache,执行了就是成功了

Pass-04 

看到提示过滤了很多的文件后缀,但是呢,没有过滤 .htaccess后缀,我们可以构建一个htaccess配置文件,文件内容为 SetHandler application/x-httpd-php  ,注意这个文件没有名字,只有后缀。这时有人的电脑无法直接创建,我们可以试试,先创建一个文本文件,写入我们的内容,另存为,选择所有文件,保存即可,这个文件是可以直接上传的,他有什么作用呢,只要有这个文件,该目录下的所有文件都会按照php进行执行,将我们mu.php,改为mu.png,最后上传他,成功执行!

Pass-05

查看提示,没有收获,从源代码中入手,我们对比一下第三关,因为从第三关开始过滤文件后缀,

3

5

可以发现第五关少了这一行,他的作用就是将大写转换为小写,那么我们就可以将mu.php改为mu.PHP进行绕过

$file_ext = strtolower($file_ext);//转换为小写

upload-labs的闯关就到这里了,后续的内容其他的博主也有做,你们也可以发动你的大脑,创新你们自己的方法。


不管是以前还是今后的内容,仅供学习交流使用,如做出危害行为,我概不负责。

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

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

相关文章

使用TLA+形式化验证Go并发程序

Writing is natures way of letting you know how sloppy your thinking is - Guindon 在2024年6月份举办的GopherCon Europe Berlin 2024[1]上&#xff0c;一个叫Raghav Roy的印度程序员(听口音判断的)分享了Using Formal Reasoning to Build Concurrent Go Systems[2]&#x…

JavaScript基础 - 基础

目录 A. 简介 B. 基础用法 一. 使用 二. 输出 C. 语法 D. HTML DOM A. 简介 JavaScript 是一种高级的、解释型的编程语言&#xff0c;主要用于网页开发&#xff0c;以下是它的简介&#xff1a; 一、历史与发展 诞生 JavaScript 于 1995 年由 Netscape 公司的 Brendan …

DataX PostgreSQL 读写支持Geometry类型

这里写目录标题 简要说明依赖代码 简要说明 通过简单修改源码中关于相关的reader、writer和DBUtil工具类&#xff0c;实现表到表之间的Geometry字段类型数据的输送&#xff0c;目前修改仅测试过在postgresql的postgis插件下的Geometry类型可行。 依赖 1.通过gitclone 或者 到…

在Nestjs使用mysql和typeorm

1. 创建项目 nest new nest-mysql-test 2. 添加config 安装 nestjs/config 包 pnpm i --save nestjs/config 添加 .env 文件 DATABASE_HOSTlocalhost DATABASE_PORT3306 DATABASE_USERNAMEroot DATABASE_PASSWORD123456 DATABASE_DBdbtest 创建 config/database.config.…

Gstreamer实现udp帧数据的转发(一)

前言 最近有个项目&#xff0c;要求实现信息分发&#xff0c;大概意思是经过了各种交换机和电台&#xff0c;经过两个信息分发软件实现udp数据的转发&#xff0c;可能包括文本、指令、音视频等数据。 例如&#xff1a;设备1 《---》 设备2&#xff08;信息分发软件1&#xff09…

兼容性测试详解

目录 前言1. 兼容性测试的定义和重要性1.1 兼容性测试的定义1.2 兼容性测试的重要性 2. 兼容性测试的类型2.1 跨浏览器测试2.1.1 跨浏览器测试的挑战2.1.2 跨浏览器测试的方法 2.2 跨平台测试2.2.1 跨平台测试的挑战2.2.2 跨平台测试的方法 3. 兼容性测试的步骤和策略3.1 测试计…

前端错误日志上报解决方案

前言 项目上线之后&#xff0c;用户如果出现错误&#xff08;代码报错、资源加载失败以及其他情况&#xff09;&#xff0c;基本上没有办法复现&#xff0c;如果用户出了问题但是不反馈或直接不用了&#xff0c;对开发者或公司来说都是损失。 由于我这个项目比较小&#xff0c…

AI绘画工具介绍:以新奇角度分析与探索AI绘画艺术与技术的交汇点

目录 前言 一、AI绘画工具的前沿技术 1.1 深度学习的进化 1.2 GANs的创新应用 1.3 风格迁移的多样化 1.4 交互式AI绘画的智能化 二、艺术与技术的交汇点 2.1 艺术创作的普及化 2.2 艺术风格的创新 2.3 艺术与科技的深度融合 三、新颖的思考角度 3.1 AI作为艺术创作…

nginx平滑重启和php-fpm平滑重启

https://www.jianshu.com/p/c7809490979ahttp://xn--nginxphp-fpm-dc3k7692b4eb248gffzdlr6cx05cfuhyucca 1.在php-fpm.conf的配置中增加配置&#xff0c;让php-fpm重启前如果存在已经在处理的请求&#xff0c;先处理完再重启&#xff1a; 2.重启命令执行前&#xff0c;先…

【Python】简单爆破破解

暴力破解是一种针对密码的破译方法&#xff0c;通过逐个推算或使用工具批量验证来找到正确的密码。暴力破解是信息安全领域中一个非常重要的话题。在当今数字化时代&#xff0c;个人信息、企业数据和各种网络服务都依赖于密码来保护安全。因此&#xff0c;破解密码成为黑客获取…

熵权法模型(评价类问题)

一. 概念 利用信息熵计算各个指标的权重&#xff0c;从而为多指标的评价类问题提供依据。 指标的变异程度越小&#xff0c;所反映的信息量也越少&#xff0c;所以其对应的权值也应该越低。 指标的变异程度&#xff08;或称为变异性、波动性&#xff09;&#xff1a;描述了一…

AI智能名片S2B2C商城小程序在社群团购平台产品供应链优化中的应用探索

摘要&#xff1a;在社群团购这一新兴零售模式迅速崛起的背景下&#xff0c;产品供应链的效率和稳定性成为制约其进一步发展的关键因素。特别是在社群团购行业尚处于初步发展阶段的今天&#xff0c;产品资源的稀缺性尤为突出。针对这一问题&#xff0c;本文深入探讨了AI智能名片…

计算机网络408考研 2021

2021 计算机网络408考研2021年真题解析_哔哩哔哩_bilibili 1 1 11 1 1 11

飞睿智能8km无人机WiFi图传模块,高清、稳定、超远距!实时传输新高度

在数字化飞速发展的今天&#xff0c;无人机已经从一个遥不可及的科幻概念&#xff0c;变成了我们日常生活中的得力助手。无论是航拍美景、农业植保&#xff0c;还是紧急救援、物流配送&#xff0c;无人机都展现出了其独特的优势。而在这背后&#xff0c;一个至关重要的技术支撑…

VUE学习-day20

VUE学习-day20 1. 下载与安装 1.1 安装Node.js Node.js是一个免费、开源、跨平台的 JavaScript 运行时环境&#xff0c;它让开发人员能够创建服务器、Web 应用、命令行工具和脚本。 我们可以通过node.js来下载vue的组件和创建vue项目 下载安装教程:https://blog.csdn.net/…

检索增强生成 (RAG)在实践中的挑战

检索增强生成 (RAG) 应用程序已成为大型语言模型 (LLM) 领域的强大工具&#xff0c;但在从原型过渡到生产环境时&#xff0c;经常面临挑战。 RAG 模型在需要深度知识整合和情境理解的应用中尤其有效&#xff0c;例如法律研究、科学文献综述和复杂的客户服务查询。检索和生成过…

mysql 中的共享锁与排他锁

mysql 中的共享锁与排他锁 1、共享锁&#xff08;Shared Lock&#xff09;2、排他锁&#xff08;Exclusive Lock&#xff09; &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在MySQL的InnoDB存储引擎中&#xff0c;锁是管理并发访问数据的关…

Leetcode—328. 奇偶链表【中等】

2024每日刷题&#xff08;153&#xff09; Leetcode—328. 奇偶链表 实现代码 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNode(int x) : val(x), next(nullptr)…

入门岛3-Git 的使用与项目构建

任务概览 任务1: 破冰活动&#xff1a;自我介绍 任务2: 实践项目&#xff1a;构建个人项目 参考&#xff1a;git流程&#xff1a; csdn1 csdn2 任务1: 破冰活动&#xff1a;自我介绍 1.Git 是一种开源的分布式版本控制系统&#xff0c;广泛应用于软件开发领域&#xff0c;尤…

DPDI Online在线kettle调度工具

1. DPDI简介 DPDI Online 是一款基于Kettle的强大在线任务调度平台&#xff0c;凭借其高效与灵活性&#xff0c;专为调度和监控Kettle客户端生成的ETL任务而设计 2. DPDI使用 2.1 DPDI登录 2.2 DPDI核心功能 2.2.1 工作台 DPDI online首页主要是显示任务监控信息&#xff…