PHP中如何处理文件上传?

  

在PHP中,可以使用`$_FILES`超全局变量来处理文件上传。具体的文件上传过程包括以下步骤:

1. 创建一个HTML表单,指定`enctype=”multipart/form-data”`属性,以支持文件上传。

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

2. 创建一个PHP脚本来处理上传的文件。通过`move_uploaded_file()`函数将临时文件移动到指定的文件路径。

<?php
$targetDirectory = "uploads/";   // 存储上传文件的目录
$targetFile = $targetDirectory . basename($_FILES["fileToUpload"]["name"]);  // 目标文件路径

if (isset($_POST["submit"])) {
  $uploadOk = 1;
  $imageFileType = strtolower(pathinfo($targetFile, PATHINFO_EXTENSION));  // 文件扩展名

  // 检查文件是否为真实的图像文件
  if (isset($_FILES["fileToUpload"])) {
    $check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
    if ($check !== false) {
      echo "File is an image - " . $check["mime"] . ".";
      $uploadOk = 1;
    } else {
      echo "File is not an image.";
      $uploadOk = 0;
    }
  }

  // 检查文件是否已经存在
  if (file_exists($targetFile)) {
    echo "File already exists.";
    $uploadOk = 0;
  }

  // 检查文件大小
  if ($_FILES["fileToUpload"]["size"] > 500000) {
    echo "File is too large.";
    $uploadOk = 0;
  }

  // 允许上传的文件类型
  $allowedTypes = array('jpg', 'jpeg', 'png', 'gif');
  if (!in_array($imageFileType, $allowedTypes)) {
    echo "Only JPG, JPEG, PNG, GIF files are allowed.";
    $uploadOk = 0;
  }

  // 最终上传结果
  if ($uploadOk == 0) {
    echo "File upload failed.";
  } else {
    if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $targetFile)) {
      echo "File uploaded successfully.";
    } else {
      echo "File upload failed.";
    }
  }
}
?>

在上面的代码中,`$_FILES[“fileToUpload”]`包含了上传文件的信息,包括文件的名称、临时路径等。使用`basename()`函数可以获取文件名,`pathinfo()`函数可以获取文件扩展名。

上述代码示例中进行了以下验证:
– 检查文件是否为真实的图像文件(通过`getimagesize()`函数实现)。
– 检查文件是否已经存在。
– 检查文件大小是否超过了限制。
– 检查文件类型是否为允许的类型。

根据应用的需求,可以根据需要进行适当的调整和扩展。

相关文章