当前位置:首页 > PHP

php实现上传文件

2026-02-16 15:05:21PHP

PHP 文件上传实现方法

创建 HTML 表单

在 HTML 表单中设置 enctype="multipart/form-data" 属性,这是文件上传必需的设置。表单方法应为 POST。

<form action="upload.php" method="post" enctype="multipart/form-data">
    <input type="file" name="fileToUpload" id="fileToUpload">
    <input type="submit" value="Upload File" name="submit">
</form>

处理上传的 PHP 脚本

创建 upload.php 文件处理上传逻辑。$_FILES 超全局数组包含所有上传文件信息。

$targetDir = "uploads/";
$targetFile = $targetDir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType = strtolower(pathinfo($targetFile, PATHINFO_EXTENSION));

文件验证检查

对上传文件进行安全检查,包括检查是否真实图片、是否已存在、大小限制等。

$check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
if($check === false) {
    $uploadOk = 0;
}

if (file_exists($targetFile)) {
    $uploadOk = 0;
}

if ($_FILES["fileToUpload"]["size"] > 500000) {
    $uploadOk = 0;
}

限制文件类型

可以限制只允许特定类型的文件上传,增强安全性。

$allowedTypes = ["jpg", "png", "jpeg", "gif"];
if(!in_array($imageFileType, $allowedTypes)) {
    $uploadOk = 0;
}

执行上传

检查所有条件后,使用 move_uploaded_file() 函数将临时文件移动到目标位置。

if ($uploadOk == 0) {
    echo "Sorry, your file was not uploaded.";
} else {
    if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $targetFile)) {
        echo "The file ". htmlspecialchars(basename($_FILES["fileToUpload"]["name"])). " has been uploaded.";
    } else {
        echo "Sorry, there was an error uploading your file.";
    }
}

安全注意事项

确保上传目录不可执行,设置适当权限。对文件名进行消毒处理,防止目录遍历攻击。

$fileName = preg_replace("/[^a-zA-Z0-9\._-]/", "", $_FILES["fileToUpload"]["name"]);

文件重命名

为避免文件名冲突和安全问题,可以为上传文件生成唯一名称。

php实现上传文件

$newFileName = uniqid() . '.' . $imageFileType;
$targetFile = $targetDir . $newFileName;

标签: 上传文件php
分享给朋友:

相关文章

php 实现自动收货

php 实现自动收货

PHP 实现自动收货功能 自动收货功能通常用于电商系统,在订单超过一定时间未手动确认收货时自动完成订单。以下是实现方法: 数据库设计 需要订单表包含以下关键字段: CREATE TABLE…

php实现队列

php实现队列

PHP实现队列的方法 队列是一种先进先出(FIFO)的数据结构,PHP可以通过多种方式实现队列功能。 使用数组模拟队列 PHP数组可以模拟队列的基本操作,通过array_push和array_shi…

php 路由实现

php 路由实现

PHP 路由实现方法 在 PHP 中实现路由功能有多种方式,以下是几种常见的实现方法: 使用原生 PHP 实现 通过解析 URL 并匹配对应的控制器和动作: $request = $_SERVER…

php实现静态

php实现静态

静态化实现方法 PHP实现静态化主要通过生成HTML文件或缓存机制来减少服务器动态解析的开销。以下是几种常见方法: 生成静态HTML文件 通过file_put_contents()将动态内容保存为H…

php无限分类的实现

php无限分类的实现

PHP无限分类的实现 无限分类是一种常见的树形结构数据组织方式,适用于商品分类、菜单管理、地区选择等场景。以下是几种实现方法: 递归实现法 递归是最直观的实现方式,通过函数自身调用来遍历子分类。数据…

php怎么实现登录功能

php怎么实现登录功能

数据库准备 创建用户表存储登录信息,通常包括用户名、密码(需加密)等字段。示例SQL: CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY…