【问题标题】:Send Image Upload data to Database将图像上传数据发送到数据库
【发布时间】:2013-12-09 04:07:44
【问题描述】:

我想将数据发送到数据库,所以当用户上传图片时,他的所有图片数据都保存在 mysql 的数据库中,请告诉我应该怎么做才能让它工作。

用户上传图片时,上传成功后可以看到此类数据

Upload: wallpaper.jpg
Type: image/jpeg
Size: 8.7072027134876 kB
Stored in: upload/wallpaper.jpg 

所以我想将这些数据保存在数据库中,例如在类型列中输入类型、在大小列中输入大小以及在链接列中类似的图像链接

这是我的 PHP 代码:

<?php
$username = "root";
    $password = "123";
    $hostname = "localhost";

    $dbhandle = mysql_connect($hostname, $username, $password) or die("Could not connect to database");

    $selected = mysql_select_db("user", $dbhandle);

$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"] <= 200000)
&& 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"] / 10024) . " kB<br>";

    if (file_exists("upload/" . $_FILES["file"]["name"]))
      {
      echo $_FILES["file"]["name"] . " already exists. ";
      }
    else
      {
      move_uploaded_file($_FILES["file"]["tmp_name"],
      "upload/" . $_FILES["file"]["name"]);
      echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
      }
    }
  }
else
  {
  echo "Invalid file";
  }
?> 

这是 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> 

【问题讨论】:

  • 你的问题是什么?你得到什么错误?
  • 您需要获取传入的数据流,可能希望对其进行 base64 编码,然后将其存储在数据库中的 BLOB 中。
  • 更好的方法是不将其存储在 BLOB 中,而是将其存储在所存储文件的参考链接中。如果你这样做,事情只会变得复杂,并且会大大增加你的数据库大小。

标签: php mysql database send


【解决方案1】:

添加:

$link="upload/" . $_FILES["file"]["name"];
$filetype=$_FILES["file"]["type"];
$filesize=$_FILES["file"]["size"];
$sql=mysql_query("INSERT INTO `tblname` (`size`,`type`,`link`) VALUES ('$filesize','$filetype','$link')") or die(mysql_error());

之后:

echo "Stored in: " . "upload/" . $_FILES["file"]["name"];

当然,您应该在保存数据之前初始化 mysql_connectmysql_select_db。当然,您的表中应该有 size,type,link

【讨论】:

  • 真正晦涩难懂,我的回答被否决,然后被接受。无论如何,感谢作者
猜你喜欢
  • 1970-01-01
  • 2016-08-28
  • 2016-08-19
  • 2020-10-06
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多