<?php
if(isset($_FILES['menubg'])){
$errors= array();
$targetDir = $_SERVER['DOCUMENT_ROOT'].'/user/usermenu_background/'.($_SESSION['user_id']).'';
// Create target dir
if (!file_exists($targetDir)) {
@mkdir($targetDir);
}
$file_name = 'menubg.jpg';
// $file_name = $_FILES['menubg']['name'];
$file_size =$_FILES['menubg']['size'];
$file_tmp =$_FILES['menubg']['tmp_name'];
$file_type=$_FILES['menubg']['type'];
$file_ext=strtolower(end(explode('.',$_FILES['menubg']['name'])));
$extensions = array('jpg');
if(in_array($file_ext, $extensions) === false){
$errors[]='extension not allowed, please choose a JPG file.';
}
if($file_size > 2097152){
$errors[]='File size must be under 2 MB';
}
if(empty($errors)==true){
move_uploaded_file($file_tmp,'user/usermenu_background/'.($_SESSION['user_id']).'/'.$file_name);
echo "No errors ";
} else {
print_r($errors);
}
}
?>
出于某种原因,每次保存表单时都会收到一条错误消息(数组 ( [0] => 扩展名不允许,请选择一个 JPG 文件。除非正在上传文件,否则不应打印。
当您上传文件时,应该检查以确保您上传的是.jpg文件。 它被困在:if(isset($_FILES['menubg'])){}
. 在我的表单上,人们并不总是会上传文件,它不应该告诉我空白文件具有不允许的扩展名。
您应该使用 is_uploaded_file
方法而不是 isset
。
在这里看到答案:如何检查用户是否在 PHP 中上传了文件?