У меня теперь есть php-файл, который загружает файлы на мой веб-сервер. В настоящее время он будет загружать файлы, такие как jpg-файлы, однако всякий раз, когда я пытаюсь загрузить excel или текстовый файл (который, честно говоря, мне нужен), он не отображает мой код и просто говорит «недопустимый файл». Я не получаю ошибок, так как это только эхо последней строки. Любые идеи были бы хорошы.Загрузка файлов в каталог
<?php
include 'dbconnect.php';
$target_path = "uploads/";
$target_path = $target_path . basename($_FILES['file']['name']);
//$allowedExts = array("gif", "jpeg", "jpg", "png");
//$temp = $target_path . basename($_FILES['file']['name']);
//$extension = end($temp);
if (($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/jpg")
|| ($_FILES["file"]["type"] == "image/pjpeg")
|| ($_FILES["file"]["type"] == "image/x-png")
|| ($_FILES["file"]["type"] == "image/png")
|| ($_FILES["file"]["type"] == "text/plain")
|| ($_FILES["file"]["type"] == "application/msword")
|| ($_FILES["file"]["type"] == "application/vnd.ms-excel")
&& ($_FILES["file"]["size"] < 2000000))
{
if ($_FILES["file"]["error"] > 0)
{
echo "Return Code: " . $_FILES["file"]["error"] . "<br>";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br>";
echo "Type: " . $_FILES["file"]["type"] . "<br>";
echo "Size: " . ($_FILES["file"]["size"]/1024) . " kB<br>";
echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br>";
if (file_exists("upload/" . $_FILES["uploadedfile"]["tmp_name"]))
{
echo $_FILES["file"]["name"] . " already exists. ";
}
else
{
move_uploaded_file($_FILES['file']['tmp_name'], $target_path);
echo "The file ". basename($_FILES['file']['name']).
" has been uploaded";
}
}
}
else
{
echo "Invalid file";
}
?>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
<title>upload</title>
</head>
<body>
<form action="upload.php" method="post"
enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file"><br>
<input type="submit" name="submit" value="Submit">
</form>
</body>
</html>
a print_r ($ _ FILES ["file"]) был бы полезным, а не недопустимым файлом. –
ваш код работает, просто увеличивайте лимит загрузки с 20000 или загружайте небольшое изображение. –
Вы переписываете '$ target_path'' $ target_path. basename ($ _FILES ['file'] ['name']); '. $ _FILES будет пустым, если файл не будет загружен, поэтому будет запущена ошибка. Кроме того, для обнаружения расширения я предпочитаю 'pathinfo()'. – Ruben