如何在MySQL数据库中存储和显示图像

时间:2014-05-10 07:11:21

标签: php mysql

我在存储和显示图像时遇到问题。代码不起作用。我想将图像上传到文件夹" img"并显示它。

这是我的代码:

<html>
<body>

<form action="upload_file.php" method="post"
enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="image" ><br>
<input type="submit" name="submit" value="Submit">
</form>

</body>
</html>

upload_file.php

<?php
$allowedExts = array("gif", "jpeg", "jpg", "png");
$temp = explode(".", $_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"]["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"] / 1024) . " kB<br>";
    echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br>";
    if (file_exists("img/" . $_FILES["file"]["name"])) {
      echo $_FILES["file"]["name"] . " already exists. ";
    } else {
      move_uploaded_file($_FILES["file"]["tmp_name"],
      "img/" . $_FILES["file"]["name"]);
      echo "Stored in: " . "img/" . $_FILES["file"]["name"];
    }
  }
} else {
  echo "Invalid file";
}
?>

1 个答案:

答案 0 :(得分:0)

嗯,您在表单的输入文件标记中为该文件指定了一个不同的名称。

更改此

<input type="file" name="image" ><br>

到这个

<input type="file" name="file" ><br>

它应该有效。如果没有,请告诉我。

您也可以考虑将upload_file.php中的内容放在if条件中,以防止它在直接访问时执行,如下所示:

<?php
if(isset($_POST['submit'])) {
    // Your code here    
}