PHP代码审计笔记--任意文件上传
0x01 最简单的文件上传
未进行文件类型和格式做合法性校验,任意文件上传
漏洞代码示例:
新建一个提供上传文件的 upload.html
<html>
<body>
<form action="upload_file.php" method="post" enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file" />
<input type="submit" name="submit" value="Submit" />
</form>
</body>
</html>
创建上传脚本 upload_file.php
<?php
if ($_FILES["file"]["error"] > )
{
echo "Error: " . $_FILES["file"]["error"] . "<br />";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br />";
echo "Type: " . $_FILES["file"]["type"] . "<br />";
echo "Size: " . ($_FILES["file"]["size"] / ) . " Kb<br />";
echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";
move_uploaded_file($_FILES["file"]["tmp_name"],"upload/" . $_FILES["file"]["name"]);
echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
}
?>
漏洞利用:可上传任意文件

这是一种非常简单文件上传方式。
基于安全方面的考虑,应增加用户上传文件的限制,比如检查文件类型、限制文件大小,限定文件路径,文件名重命名、白名单限制文件上传类型等。
0x02 upload-labs
推荐一个很不错的项目,提供了各种上传漏洞的靶场,可以从upload-labs总结上传漏洞及其绕过的技巧。
GitHub项目地址:https://github.com/c0ny1/upload-labs
Pass-
js判断文件上传文件类型,抓包绕过 Pass-
文件类型匹配,抓包修改Content-Type: image/jpeg Pass-~Pass10
黑名单过滤 Pass11~Pass12
白名单,上传路径拼接,可截断 Pass13~Pass16
文件头判断,图片马绕过 Pass17~Pass18
先上传后删除,条件竞争 Pass19
文件名可控,move_uploaded_file()函数 00截断绕过 Pass20
文件名可控,数组方式绕过

PHP代码审计笔记--任意文件上传的更多相关文章
- 代码审计之XiaoCms(后台任意文件上传至getshell,任意目录删除,会话固定漏洞)
		0x00 前言 这段时间就一直在搞代码审计了.针对自己的审计方法做一下总结,记录一下步骤. 审计没他,基础要牢,思路要清晰,姿势要多且正. 下面是自己审计的步骤,正在逐步调整,寻求效率最高. 0x01 ... 
- [代码审计]eyoucms前台未授权任意文件上传
		0x00 背景 来公司差不多一年了,然而我却依旧没有转正.约莫着转正也要到九月了,去年九月来的,实习,转正用了一年.2333 废话不多说了,最近有其他的事要忙,很久没有代码审计了.难的挖不了,浅的没意 ... 
- [代码审计]XiaoCms(后台任意文件上传至getshell,任意目录删除,会话固定漏洞)
		0x00 前言 这段时间就一直在搞代码审计了.针对自己的审计方法做一下总结,记录一下步骤. 审计没他,基础要牢,思路要清晰,姿势要多且正. 下面是自己审计的步骤,正在逐步调整,寻求效率最高. 0x01 ... 
- 【代码审计】JTBC(CMS)_PHP_v3.0 任意文件上传漏洞分析
		0x00 环境准备 JTBC(CMS)官网:http://www.jtbc.cn 网站源码版本:JTBC_CMS_PHP(3.0) 企业版 程序源码下载:http://download.jtbc. ... 
- 【代码审计】QYKCMS_v4.3.2 任意文件上传漏洞分析
		0x00 环境准备 QYKCMS官网:http://www.qykcms.com/ 网站源码版本:QYKCMS_v4.3.2(企业站主题) 程序源码下载:http://bbs.qingyunke. ... 
- 【代码审计】CLTPHP_v5.5.3 前台任意文件上传漏洞分析
		0x00 环境准备 CLTPHP官网:http://www.cltphp.com 网站源码版本:CLTPHP内容管理系统5.5.3版本 程序源码下载:https://gitee.com/chich ... 
- 【代码审计】CLTPHP_v5.5.3 前台任意文件上传漏洞
		0x00 环境准备 CLTPHP官网:http://www.cltphp.com 网站源码版本:CLTPHP内容管理系统5.5.3版本 程序源码下载:https://gitee.com/chichu/ ... 
- 【原创】JEECMS v6~v7任意文件上传漏洞(1)
		文章作者:rebeyond 受影响版本:v6~v7 漏洞说明: JEECMS是国内Java版开源网站内容管理系统(java cms.jsp cms)的简称.该系统基于java技术开发,继承其强大.稳定 ... 
- 中国电信某站点JBOSS任意文件上传漏洞
		1.目标站点 http://125.69.112.239/login.jsp 2.简单测试 发现是jboss,HEAD请求头绕过失败,猜测弱口令失败,发现没有删除 http://125.69.112. ... 
随机推荐
- 自然语言交流系统 phxnet团队 创新实训 项目博客 (八)
			在本项目中使用到的“文本转语音”的技术总结: 文本转语音,使用的是科大讯飞的接口,因为此作品之中语音包不是重点,所以语音包的转换我们统一调用的科大讯飞的语音包接口,依旧是在线的文字转语音,客户端将来自 ... 
- 使用 pv 命令监控 linux 命令的执行进度
			如果你是一个 linux 系统管理员,那么毫无疑问你必须花费大量的工作时间在命令行上:安装和卸载软件,监视系统状态,复制.移动.删除文件,查错,等等.很多时候都是你输入一个命令,然后等待很长时间直到执 ... 
- VidLoc: A Deep Spatio-Temporal Model for 6-DoF Video-Clip Relocalization
			用双向lstm对序列图片做相机定位. 
- 从LeNet到SENet——卷积神经网络回顾
			从LeNet到SENet——卷积神经网络回顾 从 1998 年经典的 LeNet,到 2012 年历史性的 AlexNet,之后深度学习进入了蓬勃发展阶段,百花齐放,大放异彩,出现了各式各样的不同网络 ... 
- mxnet卷积计算
			#coding:utf-8 ''' 卷积计算 ''' import mxnet as mx from mxnet.gluon import nn from mxnet import ndarray a ... 
- (转)关于yuv 格式:planar和semi-planar格式
			关于yuv 格式 YUV 格式通常有两大类:打包(packed)格式和平面(planar)格式.前者将 YUV 分量存放在同一个数组中,通常是几个相邻的像素组成一个宏像素(macro-pixel);而 ... 
- asp.net Core  EF core ( Entity Framework 7 ) 数据库更新维护
			CreateDatabaseIfNotExists等之前的API已经废弃,现在采用的是微软封装好,简化.高效的API,migrations 因为,旧API,要付出高昂的代价,以及局限性 打开VS20 ... 
- QComboBox:类似于的百度的搜索提示
			参考: http://blog.csdn.net/lingchen214/article/details/17960789 http://blog.sina.com.cn/s/blog_a6fb6cc ... 
- systemd的运行级别与服务管理命令简介
			从很久很久以前我们就在使用静态运行级别.而systemd提供了更为动态灵活的机制,来管控你的系统. 在开始介绍systemd命令前,让我们先简单的回顾一下历史.在Linux世界里,有一个很奇怪的现象, ... 
- df命令/du命令/磁盘分区
			4.1 df命令 4.2 du命令 4.3/4.4 磁盘分区 df命令 磁盘管理df 大小单位是KB,挂载点是linux上的目录 df -h 根据磁盘大小适当调整单位;单位有:Byte ,1KB,1M ... 
