登录
首页 >  文章 >  php教程

PHP视频上传完整教程及代码实现

时间:2025-10-12 09:57:48 325浏览 收藏

文章小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《PHP视频上传教程:完整代码实现方法》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


首先创建前端表单供用户选择并提交视频文件,接着通过PHP后端处理上传,包括检查错误、限制大小为100MB、验证MIME类型为mp4/avi/mov/webm之一,并生成唯一文件名保存至uploads目录,同时建议配置php.ini、禁用执行权限和使用FFmpeg处理视频以增强安全性和功能性。

php视频怎么上传_php实现视频上传的完整代码

要实现 PHP 视频上传功能,需要从前端表单、后端处理到文件安全验证等多个环节进行完整配置。下面是一个实用且安全的视频上传实现方案。

前端 HTML 表单

用户通过表单选择视频文件并提交:

<form action="upload.php" method="post" enctype="multipart/form-data">
    <label for="video">选择视频文件:</label>
    &lt;input type=&quot;file&quot; name=&quot;video&quot; id=&quot;video&quot; accept=&quot;video/*&quot; required&gt;
    <button type="submit">上传视频</button>
</form>

后端 PHP 处理代码(upload.php)

PHP 脚本负责接收上传的文件,并进行类型、大小和安全性检查:

<?php
$uploadDir = 'uploads/'; // 保存视频的目录
$allowedTypes = ['video/mp4', 'video/avi', 'video/mov', 'video/webm'];
$maxFileSize = 100 * 1024 * 1024; // 最大 100MB
<p>if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_FILES['video'])) {
$file = $_FILES['video'];</p><pre class="brush:php;toolbar:false;">// 检查上传错误
if ($file['error'] !== UPLOAD_ERR_OK) {
    die('文件上传出错:' . $file['error']);
}

// 验证文件大小
if ($file['size'] > $maxFileSize) {
    die('文件太大,不能超过 100MB');
}

// 验证 MIME 类型
$finfo = finfo_open(FILEINFO_MIME_TYPE);
$mimeType = finfo_file($finfo, $file['tmp_name']);
finfo_close($finfo);

if (!in_array($mimeType, $allowedTypes)) {
    die('不支持的视频格式,请上传 MP4、AVI、MOV 或 WebM 文件');
}

// 创建上传目录(如果不存在)
if (!is_dir($uploadDir)) {
    mkdir($uploadDir, 0755, true);
}

// 生成唯一文件名防止覆盖
$extension = pathinfo($file['name'], PATHINFO_EXTENSION);
$fileName = uniqid('video_', true) . '.' . $extension;
$filePath = $uploadDir . $fileName;

// 移动文件到目标目录
if (move_uploaded_file($file['tmp_name'], $filePath)) {
    echo "视频上传成功!访问地址:&lt;a href='$filePath' target='_blank'&gt;$filePath&lt;/a&gt;";
} else {
    echo "文件保存失败,请检查目录权限";
}

} ?>

服务器与安全建议

确保上传功能稳定安全,需注意以下几点:

  • 设置 php.ini 限制:调整 upload_max_filesize 和 post_max_size,例如设为 100M
  • 禁止执行权限:在 uploads 目录放置 .htaccess(Apache)或限制 Nginx 执行 PHP
  • 重命名文件:避免使用原始文件名,防止路径遍历攻击
  • 验证扩展名与 MIME 类型双重检查:仅依赖扩展名容易被绕过
  • 考虑加水印或转码:可结合 FFmpeg 进一步处理视频

基本上就这些。这套代码可以直接运行在普通 PHP 环境中,适合中小型项目使用。

文中关于FFmpeg,HTML表单,PHP视频上传,后端PHP处理,文件安全验证的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《PHP视频上传完整教程及代码实现》文章吧,也可关注golang学习网公众号了解相关技术文章。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>