そのため、特定のファイル タイプのみを許可するアップロード機能を連絡先ページに追加しようとしています。ファイルは「アップロード」フォルダーのルートに保存する必要があります。しかし、ファイルがアップロードされず、PDF と docx ファイルで (プログラムされたように) 「無効なファイル」エラーが発生しますが、その理由がわかりません。誰でも洞察を提供できますか?
<?php
if($_POST) {
if($_POST["token"]==true){
$allowedExts = array("pdf","docx", "doc");
$temp = explode(".", $_FILES["file"]["name"]);
$extension = end($temp);
if ((($_FILES["file"]["type"] == "application/pdf")
|| ($_FILES["file"]["type"] == "application/docx")
|| ($_FILES["file"]["type"] == "application/doc"))
&& ($_FILES["file"]["size"] < 20000)
&& in_array($extension, $allowedExts))
{
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"] / 6144) . " kB<br>";
echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br>";
if (file_exists("upload/" . $_FILES["file"]["name"]))
{
echo $_FILES["file"]["name"] . " already exists. ";
}
else
{
move_uploaded_file($_FILES["file"]["tmp_name"],"upload/" . rand().$extension);
echo "Stored in: " . "upload/" . "rand().$extension)";
}
}
}
else
{
echo "Invalid file";
}
?>