0

0

PHP文件怎么上传_PHP实现文件上传功能教程【指南】

星夢妙者

星夢妙者

发布时间:2026-02-20 15:06:09

|

452人浏览过

|

来源于php中文网

原创

php文件上传必须严格校验$_files['error']、用move_uploaded_file()落盘、重命名并校验真实mime类型、防范大文件超时,否则易致文件丢失或安全漏洞。

php文件怎么上传_php实现文件上传功能教程【指南】

PHP 文件上传不是靠前端按钮“点一下”就完事的,关键在服务端对 $_FILES 的正确解析、校验和落盘操作。漏掉任意一环,轻则文件丢失,重则被写入恶意脚本。

PHP 文件上传必须检查 $_FILES['xxx']['error']

这是最常被跳过的一步——直接用 $_FILES['file']['tmp_name'] 去移动文件,结果发现怎么都传不成功。因为 $_FILES['file']['error'] 不为 0 就说明上传已失败,可能是超限、临时目录不可写、表单未设 enctype="multipart/form-data" 等。

  • 0:上传成功
  • 12:文件大小超过 upload_max_filesizeMAX_FILE_SIZE 隐藏字段限制
  • 3:文件只有部分被上传(网络中断等)
  • 4:没有文件被上传($_FILES 为空)
  • 68:临时目录缺失、php.ini 配置禁用上传、超时等系统级问题

务必先判断:

if ($_FILES['avatar']['error'] !== UPLOAD_ERR_OK) {<br>    die('上传失败:' . $_FILES['avatar']['error']);<br>}

move_uploaded_file() 是唯一安全的落盘方式

别用 copy()rename() 或直接 file_put_contents(file_get_contents()) 处理 $_FILES['x']['tmp_name']。PHP 的临时文件路径可能指向共享临时区,且 tmp_name 并非普通文件路径,而是上传上下文绑定的句柄标识。只有 move_uploaded_file() 会验证该文件确由本次上传生成,防止 LFI 或文件覆盖攻击。

Cognitive Mill
Cognitive Mill

一个云计算平台,可以分析视频并自动生成预告片

下载

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

  • 目标路径必须是绝对路径,相对路径容易因工作目录变化出错
  • 目标目录需有 webserver 用户(如 www-data)的写权限,但不能开放执行权限(禁止 chmod 755 到上传目录)
  • 建议用 dirname(__FILE__) 拼接,例如:move_uploaded_file($_FILES['f']['tmp_name'], __DIR__ . '/uploads/' . $safe_name)

文件名和类型校验不能只信客户端传来的 $_FILES['x']['name']['type']

$_FILES['x']['name'] 可被任意篡改,['type'] 完全由浏览器发送,毫无可信度。真实 MIME 类型必须用 finfo_file()getimagesize()(仅图片)二次确认;文件名要过滤掉路径遍历字符(../)、空字节、控制符,并强制重命名。

  • pathinfo($name, PATHINFO_EXTENSION) 提取扩展名,再白名单比对(如 in_array(strtolower($ext), ['jpg', 'png', 'pdf'])
  • finfo_open(FILEINFO_MIME_TYPE) 读取真实类型,拒绝 text/htmlapplication/x-php 等危险类型
  • 生成新文件名推荐用 uniqid() . '_' . random_int(1000, 9999),避免时间戳或用户输入参与命名

大文件上传需要调低超时并分段处理

默认 max_execution_time=30post_max_size=8M 对几十 MB 文件根本不够。单纯调高 php.ini 参数只是权宜之计,真要支持大文件,得结合前端分片(如使用 WebUploaderUppy)+ 后端合并逻辑,否则用户刷新页面就前功尽弃。

  • 临时增加超时:set_time_limit(300)(慎用,可能影响其他请求)
  • 确保 upload_max_filesizepost_max_size 同步调大,且后者 ≥ 前者 + 表单其他字段体积
  • 上传中不要做耗时校验(如病毒扫描),应先落盘再异步处理

真正难的不是“怎么把文件存到服务器”,而是“怎么确认它安全、可控、可追溯”。从 $_FILES 出现那一刻起,每一步都要带着怀疑去验证——它是不是真的?有没有被污染?路径是否越界?权限是否最小化?这些细节不卡死,功能越完整,风险越隐蔽。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.25

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.25

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

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

776

2026.02.13

微博网页版主页入口与登录指南_官方网页端快速访问方法
微博网页版主页入口与登录指南_官方网页端快速访问方法

本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

247

2026.02.13

Flutter跨平台开发与状态管理实战
Flutter跨平台开发与状态管理实战

本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

141

2026.02.13

TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

24

2026.02.13

Redis高可用架构与分布式缓存实战
Redis高可用架构与分布式缓存实战

本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

69

2026.02.13

热门下载

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

精品课程

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

共137课时 | 12.2万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 0.9万人学习

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

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