4

我一直在试验php的上传功能,我一直在看w3school上的这个教程。

http://www.w3schools.com/php/php_file_upload.asp

I installed this script on MYDOMAIN.com/New.html


<html>
<body>

<form action="upload_file.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>

然后我把这个片段放在 MYDOMAIN.com/upload_file.php

<?php
$allowedExts = array("jpg", "jpeg", "gif", "png");
$extension = end(explode(".", $_FILES["file"]["name"]));
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/png")
|| ($_FILES["file"]["type"] == "image/pjpeg"))
&& ($_FILES["file"]["size"] < 20000)
&& in_array($extension, $allowedExts))
  {
  if ($_FILES["file"]["error"] > 0)
    {
    echo "Error: " . $_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 "Stored in: " . $_FILES["file"]["tmp_name"];
    }
  }
else
  {
  echo "Invalid file";
  }
?>

现在很有可能我只是一个非常困惑的人,但我认为应该做的是将我放入 New.html 文件的文件,如果它是一个图像文件,将它上传到我的目录,而不是它的只是输出无效文件我不知道该怎么做任何帮助非常希望很快能收到回复谢谢

4

6 回答 6

10

您的脚本的问题是您可能正在尝试上传比您的限制更高的文件!您指定了一个非常低的最大文件大小!打印出您的 $_FILES 变量以获取有关问题的信息;)

但是,为了将文件移动到您的文件夹,您仍然需要使用move_uploaded_file

$allow = array("jpg", "jpeg", "gif", "png");

$todir = 'uploads/';

if ( !!$_FILES['file']['tmp_name'] ) // is the file uploaded yet?
{
    $info = explode('.', strtolower( $_FILES['file']['name']) ); // whats the extension of the file

    if ( in_array( end($info), $allow) ) // is this file allowed
    {
        if ( move_uploaded_file( $_FILES['file']['tmp_name'], $todir . basename($_FILES['file']['name'] ) ) )
        {
            // the file has been moved correctly
        }
    }
    else
    {
        // error this file ext is not allowed
    }
}
于 2012-11-20T10:09:34.237 回答
2

我认为上传图像的最佳方法是复制图像并存储在文件夹中,然后将图像的新位置存储到数据库中。

要移动文件,我们可以使用 move_uploaded_file 函数

$oldpath = $_FILES['image']['tmp_name'];
$newpath ="new_folder_location/".$_FILES['image']['name'];
move_uploaded_file($oldpath, $newpath);
于 2012-11-20T09:56:43.010 回答
1

您的验证代码正在检查扩展名、mime 类型和文件大小。

您可能正在上传扩展名中包含大写字符的文件。当你检查扩展名时,你检查它区分大小写,.JPG是一个有效的图像文件扩展名,所以你应该让你的检查不区分大小写:

if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/png")
|| ($_FILES["file"]["type"] == "image/pjpeg"))
&& ($_FILES["file"]["size"] < 20000)
&& in_array(strtolower($extension), $allowedExts))
         // ^ added strtolower()

如果这不是直接的问题,那么文件太大或 MIME 类型错误。要调试,请使用以下命令查看 files 数组:

print_r($_FILES);
于 2012-11-20T10:02:20.260 回答
1

我会说问题在于如果,那里有很多条件(“无效文件”也是那个 if 的 Else 部分),尝试简化它以跟踪问题,乍一看我会说这是因为大小检查:

&& ($_FILES["file"]["size"] < 20000)

大约 20Kb,对于图像来说非常小,如果您要上传照片,请尝试设置更高的值或取出该条件并查看脚本是否有效

于 2012-11-20T10:03:42.563 回答
0

发生这种情况是因为以下表达式的计算结果为 false:

(($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/png")
|| ($_FILES["file"]["type"] == "image/pjpeg"))
&& ($_FILES["file"]["size"] < 20000)
&& in_array($extension, $allowedExts)

这意味着要么

  • 文件类型不正确(不是 GIF/JPEG/PNG/PNJPEG 文件)
  • 文件大于 20000 字节
  • 文件扩展名不正确(不是“jpg”、“jpeg”、“gif”、“png”)

我的猜测是文件大小 - 大幅增加。将其更改为以下内容以允许最大 10 MB 的大小:

&& ($_FILES["file"]["size"] < 10485760)

查看问题的最佳方法是将此行添加到脚本的开头:

var_dump($_FILES);
于 2012-11-20T09:57:01.080 回答
0

我同意 Ivo 的回答,但我认为您可以像这样更改下一段代码:

$typePicture = array('jpg','png','jpeg','gif');

// Allow certain file formats

if($typePicture[0] != "jpg" || $typePicture[1] != "png" || $typePicture[2] != "jpeg" || $typePicture[3] != "gif" ) 
{
    echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
    $uploadOk = 0;
}
于 2016-06-01T01:01:23.827 回答