PHP中的文件上传给出错误
我正在使用PHP构建一个Web应用程序。我正在创建一个文件上传部分,但我遇到了问题。
<form action="upload.php" method="post" enctype="multipart/form-data">
Select image to upload:
<input type="file" name="fileToUpload" id="fileToUpload">
<input type="submit" value="Upload Image" name="submit">
</form>
upload.php的:
<?php
$target_dir = "images/";
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType = pathinfo($target_file,PATHINFO_EXTENSION);
// Check if image file is a actual image or fake image
if(isset($_POST["submit"])) {
$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;
}
}
// Check if file already exists
if (file_exists($target_file)) {
echo "Sorry, file already exists.";
$uploadOk = 0;
}
// Check file size
if ($_FILES["fileToUpload"]["size"] > 500000) {
echo "Sorry, your file is too large.";
$uploadOk = 0;
}
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
// Check if $uploadOk is set to 0 by an error
if ($uploadOk == 0) {
echo "Sorry, your file was not uploaded.";
// if everything is ok, try to upload file
} else {
if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
echo "The file ". basename( $_FILES["fileToUpload"]["name"]). " has been uploaded.";
} else {
echo "Sorry, there was an error uploading your file.";
}
}
?>
它对图像工作正常。 但是当我尝试检查如果我上传MP4文件会发生什么。 它回声文件已经存在,对不起,只允许JPG,JPEG,PNG和GIF文件。可以,上传文件时出错。 请引导我在哪里做错误,以便这项工作适合我,而不会有错误。 提前致谢。
它对图像工作正常。 但是当我尝试检查如果我上传MP4文件会发生什么。 它回声对不起,只允许JPG,JPEG,PNG和GIF文件
这仅仅是因为你的代码限制了它的限制。
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
如果该文件不是jpg
, png
, jpeg
或gif
,则不允许上传。
它的回声文件已经存在
这只是因为该文件已经存在(无论目录在哪里),由于此检查:
// Check if file already exists
if (file_exists($target_file)) {
echo "Sorry, file already exists.";
$uploadOk = 0;
}
抱歉,上传文件时出错
我看不出这是为什么。 您的条件if ($uploadOk == 0)
在所有其他条件中设置为0,因此应该为true,并且应该回显“对不起,您的文件未上传”。
转移到评论问。
因为你有不允许其他扩展的条件,所以它根据代码工作:
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg" && $imageFileType != "gif" ) {
echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
显然你已经在你的目标文件夹中有这样的文件。 再次检查。
HTML代码
<form method="POST" enctype="multipart/form-data">
<input id="tags" type="file" name="employer_image" />
<input type="submit" name="submit" value="submit">
</form
upload.php的
if (isset( $_POST['submit'] )
{
function GetImageExtension($imagetype)
{
if(empty($imagetype)) return false;
switch($imagetype)
{
case 'image/bmp': return '.bmp';
case 'image/gif': return '.gif';
case 'image/jpeg': return '.jpg';
case 'image/png': return '.png';
default: return false;
}
}
if (!empty($_FILES["employer_image"]["name"])) {
$file_name=$_FILES["employer_image"]["name"];
$temp_name=$_FILES["employer_image"]["tmp_name"];
$imgtype=$_FILES["employer_image"]["type"];
$ext= GetImageExtension($imgtype);
$imagename=date("d-m-Y").'-'.time().$ext;
$target_path = "folder-path".$imagename;
if(move_uploaded_file($temp_name, $target_path)) {
/* write insert query for store in mysql*/
}else{
exit("Error While uploading image on the server");
}
}
}
首先选择文件形式您的本地后点击提交按钮它的重定向到upload.php文件有第一个功能是白色的,找到文件的扩展名,它返回您的文件扩展名,你需要创建一个文件夹(你可以存储名称)在扩展代码之后,它将获得带有日期和时间的文件名,并且您可以设置保存图像的文件的目标路径,并在此之后运行插入查询。 首先检查您可以移动文件的文件夹权限
谢谢Vivek
链接地址: http://www.djcxy.com/p/69639.html