0

0

如何安全读取用户上传文件_PHP安全读取上传文件注意要点【说明】

看不見的法師

看不見的法師

发布时间:2026-02-18 10:20:32

|

451人浏览过

|

来源于php中文网

原创

安全读取用户上传文件需五步:一、验证上传状态并用fileinfo校验真实mime类型;二、过滤路径字符并检查realpath是否在允许目录内;三、禁用危险解析方式,优先用json_decode;四、限制文件大小与分块读取;五、设置临时文件权限为0600并立即清理。

如何安全读取用户上传文件_php安全读取上传文件注意要点【说明】

如果您在PHP应用中需要读取用户上传的文件,但未对文件内容和路径进行严格校验,则可能引发任意文件读取、路径遍历或代码执行等安全风险。以下是安全读取用户上传文件的关键要点:

一、验证文件上传状态与类型

PHP中$_FILES数组仅反映客户端提交的上传元信息,不能直接信任。必须通过is_uploaded_file()确认文件确实由HTTP POST上传,并结合fileinfo扩展获取真实MIME类型,而非依赖$_FILES['type']字段(该字段可被篡改)。

1、使用is_uploaded_file($_FILES['file']['tmp_name'])判断临时文件是否为合法上传文件。

2、调用finfo_open(FILEINFO_MIME_TYPE)获取文件实际二进制类型,例如检测是否为text/plain或application/pdf。

立即学习PHP免费学习笔记(深入)”;

3、将获取到的真实MIME类型与白名单数组比对,拒绝一切不在白名单中的类型,包括image/svg+xml、text/x-php等高危类型

二、禁止直接使用用户输入构造文件路径

用户提交的文件名、ID或参数若未经处理即拼接进file_get_contents()、fopen()等函数,极易触发路径遍历(如../etc/passwd)。必须剥离所有路径字符并强制限定读取范围。

1、对用户传入的文件标识符(如filename、id)执行basename()或正则过滤,仅保留字母、数字、下划线和短横线,彻底移除点号、斜杠、反斜杠

2、将清理后的名称与预设的安全目录路径拼接,例如$real_path = '/var/www/uploads/' . $clean_name;

3、调用realpath($real_path)获取绝对路径后,检查其是否仍位于允许目录内:若strpos(realpath($real_path), '/var/www/uploads/') !== 0,则立即中止读取

三、禁用危险文件解析与执行

即使文件存储于Web不可访问目录,若后续以PHP、XML、YAML等方式解析其内容,仍可能导致远程代码执行或XXE攻击。必须隔离解析上下文并禁用外部实体。

宜萱网络企业网站管理系统 1.0
宜萱网络企业网站管理系统 1.0

后台管理入口:http://网站名/admin/用户名:admin 密码:admin安装说明:后台主要功能如下:一、系统管理:管理员管理,可以新增管理员及修改管理员密码;数据库备份: 为保证您的数据安全本系统采用了数据库备份功能 上传文件管理:管理你增加产品时上传的图片及其他文件。 二、企业信息:可设置修改企业的各类信息及介绍。 三、产品管理:产品类别新增修改管理,产品添加修改以及产品的审核。 四

下载

1、读取文件后,若需解析为结构化数据,优先使用json_decode()而非eval()、create_function()或unserialize()。

2、若必须解析XML,初始化libxml_disable_entity_loader(true),并在simplexml_load_string()前调用libxml_clear_errors()。

3、绝对禁止将用户上传文件内容作为PHP代码执行,包括include()、require()、eval()及其变体

四、限制文件大小与读取长度

超大文件读取可能耗尽内存或触发超时,恶意构造的超长行或嵌套结构还可能引发解析器栈溢出。应主动控制资源消耗边界。

1、在php.ini中设置upload_max_filesize和post_max_size,并在脚本中通过$_FILES['file']['size']二次校验。

2、使用fopen()配合fread()分块读取,每次最多读取8192字节,累计超过预设阈值(如5MB)即终止。

3、对文本类文件,读取前先检测BOM头及首行长度,单行超过1024字符视为异常并拒绝处理

五、设置临时文件权限与及时清理

上传后的临时文件若权限宽松或长期残留,可能被其他进程读取或覆盖,造成信息泄露或竞争条件漏洞。

1、调用chmod($_FILES['file']['tmp_name'], 0600)将临时文件权限设为仅属主可读写。

2、读取完成后立即调用unlink($_FILES['file']['tmp_name'])删除临时文件,不得延迟至脚本结束或依赖auto_cleanup机制

3、若需暂存已校验文件,保存至独立隔离目录(如/var/www/uploaded_safe/),并确保该目录无Web服务器执行权限且不被公开访问。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

481

2023.11.27

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1929

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2104

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1125

2024.11.28

mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

195

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

304

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

272

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

138

2025.08.07

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

462

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.2万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号