「 典型安全漏洞系列 」08.文件上传漏洞详解

news2024/11/19 17:21:09

文件上传功能可被攻击者用作一系列高严重性攻击的强大载体。本文最后将会展示如何绕过常见的防御机制来上传web shell,使你能够完全控制一个易受攻击的web服务器。

在这里插入图片描述

1. 简介

文件上传漏洞是指web服务器允许用户在没有充分验证文件名、类型、内容或大小等信息的情况下将文件上传到其文件系统。如果不能正确执行这些限制,可能意味着即使是基本的图像上传功能也可以用来上传任意和潜在危险的文件。这甚至可以包括启用远程代码执行的服务器端脚本文件。

主要危害有:

  • 文件覆盖
  • WebShell后门
  • DDOS攻击:可通过上传zip炸弹或并发持续上传文件让目标服务器宕机
  • 敏感信息泄露

2. 产生根因

  • 多数网站很少对用户上传的文件进行限制。
  • 开发人员实现他们认为稳健的验证,这些验证要么存在固有缺陷,要么很容易被绕过。

    举例:危险文件类型的黑名单不足防止用户上传恶意脚本,常用的方法是将php等潜在危险的文件扩展名列入黑名单。将其列入黑名单的做法本身就有缺陷,因为很难明确地阻止所有可能用于执行代码的文件扩展。这种黑名单有时可以通过使用鲜为人知的、仍然可以执行的替代文件扩展名(如.php5、.shtml等)来绕过。

2.1. 背景知识:Web服务器如何处理对静态文件的请求?

服务器解析请求中的路径以标识文件扩展名。然后,它使用它来确定所请求的文件的类型,通常是通过将其与扩展名和MIME类型之间的预配置映射列表进行比较。接下来会发生什么取决于文件类型和服务器的配置。

  • 如果此文件类型是不可执行的,例如图像或静态HTML页面,则服务器可能只是在HTTP响应中将文件的内容发送给客户端。

  • 如果文件类型是可执行的,例如PHP文件,并且服务器被配置为执行这种类型的文件,则在运行脚本之前,它将根据HTTP请求中的头和参数分配变量。所得到的输出然后可以在HTTP响应中被发送到客户端。

  • 如果文件类型是可执行的,但服务器未配置为执行此类型的文件,则通常会以错误响应。但是,在某些情况下,文件的内容仍然可以作为纯文本提供给客户端。这种错误配置偶尔会被用来泄露源代码和其他敏感信息。

3. 防御方法

允许用户上传文件是很常见的功能,只要你采取正确的预防措施,就可以消减险。一般来说,保护网站免受这些漏洞攻击的最有效方法是实施以下所有做法:

  • 文件后缀名白名单校验:根据允许的扩展名白名单而不是禁止的扩展名黑名单检查文件扩展名。猜测你可能想要允许哪些扩展比猜测攻击者可能试图上传哪些扩展要容易得多。
  • 确保文件名不包含任何可能被解释为目录或遍历序列(../)的子字符串
  • 重命名上传的文件以避免可能导致覆盖现有文件的冲突
  • 在完全验证文件之前,不要将文件上载到服务器的永久文件系统
  • 文件名校验过滤,避免文件路径遍历
  • 文件路径校验前先进行标准化处理
  • 文件上传权限控制要合理
  • 文件存储前的大小校验
  • 文件上传后及时销毁
  • 文件存储权限最小化、存储目录划分合理

4. 利用不受限制的文件上传来部署web shell

Web Shell是一种恶意脚本,其目的是获得服务器的执行操作权限。Web Shell常常被称为入侵者通过网站端口对网站服务器的某种程度上操作的权限。Web Shell常常以asp、php、jsp或cgi等网页文件形式存在,也可以将其称做为一种网页后门。黑客通常利用常见的漏洞,如SQL注入、远程文件包含 (RFI)、FTP,甚至使用社会工程学等手段来获取Web Shell。

从安全角度来看,最糟糕的情况是网站允许你上传服务器端脚本,如PHP、Java或Python文件,并配置为将其作为代码执行。这使得在服务器上创建自己的web shell变得微不足道。

如果你能够成功上传一个web shell,你就可以有效地完全控制服务器。这意味着你可以读取和写入任意文件,泄露敏感数据,甚至可以使用服务器来转移针对内部基础设施和网络外其他服务器的攻击。例如,以下PHP一行代码可用于从服务器的文件系统读取任意文件:

<?php echo file_get_contents('/path/to/target/file'); ?>

一旦上传,发送对此恶意文件的请求将在响应中返回目标文件的内容。

一个更通用的web shell可能看起来像这样:

<?php echo system($_GET['command']); ?>

此脚本使你通过查询参数传递任意系统命令,如下所示:

GET /example/exploit.php?command=id HTTP/1.1

5. 参考

[1] https://portswigger.net/web-security/file-upload


推荐阅读:

「 典型安全漏洞系列 」07.OS命令注入详解
「 典型安全漏洞系列 」06.路径遍历(Path Traversal)详解
「 典型安全漏洞系列 」05.XML外部实体注入XXE详解
「 典型安全漏洞系列 」04.服务器端请求伪造SSRF详解
「 典型安全漏洞系列 」03.跨站请求伪造CSRF详解
「 典型安全漏洞系列 」02.SQL注入详解
「 典型安全漏洞系列 」01.跨站脚本攻击XSS详解

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

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

相关文章

OJ_糖果分享游戏

题干 c实现 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<vector> using namespace std;void ShareCandy(vector<int>& student) {int size student.size();vector<int> share(size); //保存每个同学交换前&#xff0c;糖果数量…

(java)idel中将对与json的相互转

1、目录结构 2、导入包 在模块下面建立lib目录将包导入模块中 包的百度网盘 链接&#xff1a;https://pan.baidu.com/s/1abNF8cOTeNb00rM7tp04iQ?pwd39wc 提取码&#xff1a;39wc 3、建立两个测试类person和dog类 public class Dog {private String name;private int age…

TypeScript(四) 运算符

1. 运算符 1.1. 描述 运算符用于执行程序代码运算。 1.2. 运算符主要包括&#xff1a; &#xff08;1&#xff09;算术运算符 &#xff08;2&#xff09;逻辑运算符 &#xff08;3&#xff09;关系运算符 &#xff08;4&#xff09;按位运算符 &#xff08;5&#xff09;赋值…

C#算法(11)—求三个点构成圆的圆心坐标和半径

前言 我们在上位机开发领域也经常会碰到根据三个点求出圆的圆心、半径等信息的场景,本文就是详细的介绍如何根据三个点使用C#代码求出三点构成的圆的圆心坐标、圆半径、三点构成的圆弧的角度。 1、3点求圆分析 A、B、C三个点都是圆上的坐标点,过向量AB做中垂线,过向量AC做…

STP生成树协议实验

实验大纲 一、什么是生成树协议 二、生成树原理 1.STP工作原理 2.STP主要参数 3.STP根网桥 4.STP协议版本 三、实验 1.构建网络拓扑结构图 2.配置IP地址&#xff08;8台PC机&#xff09;&#xff1a;192.168.7.1~192.168.7.8 3.配置SW1 4.配置SW2 5.配置SW3 6.配置…

【英语趣味游戏】填字谜(Crossword)第1天

谜题出处 柯林斯字谜大全&#xff08;6&#xff09;&#xff0c;Collins——Big Book of Crosswords&#xff08;Book 6&#xff09; Puzzle Number: 114 本期单词 横向 1、Situation involving danger (4) 包含危险的情境&#xff0c;4个字母 答案&#xff1a;Risk&#xff…

第十一章 Linux实际操作——进程管理(重点)

第十一章 Linux实际操作——进程管理&#xff08;重点&#xff09; 11.1 基本介绍11.2 显示系统执行的进程11.2.1 基本介绍11.2.2 ps详解11.2.3 应用实例 11.3 终止进程kill和killall11.3.1 介绍11.3.2 基本语法11.3.3 常用选项11.3.4 最佳实践 11.4查看进程树pstree11.4.1 基本…

微服务-微服务Spring-cloud-open-feign

1. LoadBalancerRestTemplate的缺陷 LoadBalancerRestTemplate进行微服务调用 BeanLoadBalancedpublic RestTemplate restTemplate() {return new RestTemplate();}//调用方式String url "http://mall-order/order/findOrderByUserId/"id;R result restTemplate.…

路由进阶

文章目录 1.路由的封装抽离2.声明式导航 - 导航链接3.声明式导航-两个类名自定义匹配的类名 4.声明式导航 - 跳转传参查询参数传参动态路传参两种传参方式的区别动态路由参数可选符 5.Vue路由 - 重定向6.Vue路由 - 4047.Vue路由 - 模式设置8.编程式导航 - 两种路由跳转9.编程式…

Nginx负载均衡下的webshell连接

一、WebShell简介 “web”的含义是显然 需要服务器开放web服务&#xff0c;“shell”的含义是 取得对服务器某种程度上操作权限。 webshell&#xff0c;顾名思义&#xff1a;web指的是在web服务器上&#xff0c;而shell是用脚本语言编写的脚本程序&#xff0c;webshell就是就…

漏洞原理MySQL注入布尔盲注入

1 判断MySql注入点是否存在 利用盲注入的方式 http://127.0.0.1/news/show.php?id46 and 11 # 正常显示 http://127.0.0.1/news/show.php?id46 and 12 # 不显示 2 获取数据库的长度 http://127.0.0.1/news/show.php?id46 and length(database())n n的范围是从 1 开始 h…

Kotlin快速入门4

Kotlin的类与对象 类的定义 Kotlin使用关键字class来声明类。后面紧跟类名字&#xff1a; class LearnKotlin { //类名&#xff1a;LearnKotlin//... } Kotlin的类可以包含&#xff1a;构造函数和初始化代码块、函数、属性、内部类、对象声明。当然&#xff0c;也可以定义一…

BGP:05 BGP自动路由汇总

路由汇总&#xff0c;能有效地减少 BGP 路由器通告的路由条目数量&#xff0c;减小设备的路由表规模&#xff0c;并将拓扑变化产生的影响限制在一个相对更小的范围内。 自动路由聚合是在自然边界路由器上自动执行的&#xff0c;在默认情况下&#xff0c;BGP的自动路由聚合功能是…

go包与依赖管理

包&#xff08;package&#xff09; 包介绍 Go语言中支持模块化的开发理念&#xff0c;在Go语言中使用包&#xff08;package&#xff09;来支持代码模块化和代码复用。一个包是由一个或多个Go源码文件&#xff08;.go结尾的文件&#xff09;组成&#xff0c;是一种高级的代码…

springboot134英语知识应用网站的设计与实现

简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计&#xff0c;课程设计参考与学习用途。仅供学习参考&#xff0c; 不得用于商业或者非法用途&#xff0c;否则&#xff0c;一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…

深度强化学习(王树森)笔记07

深度强化学习&#xff08;DRL&#xff09; 本文是学习笔记&#xff0c;如有侵权&#xff0c;请联系删除。本文在ChatGPT辅助下完成。 参考链接 Deep Reinforcement Learning官方链接&#xff1a;https://github.com/wangshusen/DRL 源代码链接&#xff1a;https://github.c…

C++多线程2(复习向)

lock_guard lock_guard是C中提供的对互斥锁有关操作的高级接口&#xff0c;可对互斥锁进行自动上锁和解锁&#xff0c;多用于作为局部变量。&#xff08;在对象创建时&#xff0c;构造函数中自动为传入的互斥锁对象上锁&#xff0c;局部变量被系统回收时&#xff0c;其析构函数…

消失的数字(c语言多种解法)

题目 该题目取自力扣&#xff08;LeetCode&#xff09;面试题 17.04. 消失的数字 该题目主要考察时间复杂度的把握&#xff0c;题目如下&#xff1a; 数组nums包含从0到n的所有整数&#xff0c;但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗&a…

幻兽帕鲁服务器出租,腾讯云PK阿里云怎么收费?

幻兽帕鲁服务器价格多少钱&#xff1f;4核16G服务器Palworld官方推荐配置&#xff0c;阿里云4核16G服务器32元1个月、96元3个月&#xff0c;腾讯云换手帕服务器服务器4核16G14M带宽66元一个月、277元3个月&#xff0c;8核32G22M配置115元1个月、345元3个月&#xff0c;16核64G3…

【MySQL】补充和navicat的一些简单使用

文章目录 前言在这里插入图片描述 事情起因因为这个articlecount的c是小写了&#xff0c;我想改成大写 一、修改二、navicat的使用步骤1.连接2.建库&#xff0c;建表 三.填写数据总结 前言 事情起因因为这个articlecount的c是小写了&#xff0c;我想改成大写 提示&#xff1a;…