要结合is_file
函数实现文件上传验证,您需要先确保用户已经成功上传文件,然后使用is_file
检查该文件是否存在。以下是一个简单的PHP示例,展示了如何实现文件上传验证:
<!DOCTYPE html>
<html>
<head>
<title>File Upload Validation</title>
</head>
<body>
<form action="upload.php" method="post" enctype="multipart/form-data">
Select file to upload:
<input type="file" name="fileToUpload" id="fileToUpload">
<input type="submit" value="Upload File" name="submit">
</form>
</body>
</html>
upload.php
的PHP文件来处理文件上传和验证:<?php
// 定义允许的文件类型
$allowed_file_types = array("jpg", "jpeg", "png", "gif");
// 检查用户是否已经提交了文件
if(isset($_FILES['fileToUpload'])) {
// 获取文件信息
$file_name = $_FILES['fileToUpload']['name'];
$file_tmp_name = $_FILES['fileToUpload']['tmp_name'];
$file_size = $_FILES['fileToUpload']['size'];
$file_error = $_FILES['fileToUpload']['error'];
// 获取文件扩展名
$file_ext = pathinfo($file_name, PATHINFO_EXTENSION);
// 检查文件类型是否允许
if(!in_array(strtolower($file_ext), $allowed_file_types)) {
echo "Error: Invalid file type.";
exit();
}
// 检查文件大小
if($file_size > 500000) {
echo "Error: File size too large.";
exit();
}
// 检查文件是否有错误
if($file_error != 0) {
echo "Error: An error occurred while uploading the file.";
exit();
}
// 使用 is_file 函数检查文件是否存在
if(!is_file($file_tmp_name)) {
echo "Error: File does not exist.";
exit();
}
// 如果所有验证都通过,将文件移动到指定目录
$target_dir = "uploads/";
$target_file = $target_dir . basename($file_name);
if(move_uploaded_file($file_tmp_name, $target_file)) {
echo "The file " . $file_name . " has been uploaded successfully.";
} else {
echo "Error: There was an error uploading the file.";
}
} else {
echo "Error: No file was submitted.";
}
?>
这个示例中,我们首先检查用户是否已经提交了文件。接下来,我们获取文件信息并进行验证,包括检查文件类型、文件大小和文件错误。最后,我们使用is_file
函数检查文件是否存在,然后将文件移动到指定目录。