链接上传图片代码与mysql

时间:2014-05-21 16:10:29

标签: php mysql upload image-uploading

我正在制作类似个人资料图片的内容。我做了一个表单上传图片和upload_file代码都成功了,但我只需要一种方法来链接上传和mysql。或任何方式使上传的图片成为个人资料图片。

这是我所做的代码:

选择图片(upload_form.php)

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

和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"] < 1048576)
&& 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("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";
}
?>

这些代码成功上传图片。所以我的下一步是如何使它成为个人资料图片??

提前

thanx

1 个答案:

答案 0 :(得分:0)

这不是一个完整的解决方案,也不包含任何代码。

但它可能会让你对高层实际需要做的事情有所了解。

<强>假设

  1. 您正在上传为个人资料照片。因此,您已经拥有用户表和代码来创建新用户。
  2. 用户将登录其帐户并上传图片
  3. 数据库 - 用户表

    1. 在用户表格中有一个名称图片列。哪个可以为null。我们将为每个用户在此字段中存储上传图片的文件名。这是一个字符串。
    2. 上传 - 处理

      1. 您已经上传了图片。现在为上传的文件名提供一些唯一的名称,而不是用户上传图片的名称。

        • 因为,用户1和用户2都可以上传名为 pic.jpg 的文件,并且您最终在上传的文件夹中只有一个 pic.jpg
        • 您的users表中每个用户应该有一些唯一字段。可能是电子邮件或用户名。因此,最好使用用户名+时间的md5哈希并将其用作文件名。
        • 不要将用户的ID用作文件名。虽然它可以帮助您快速获得代码,但是一些带有简单脚本的正文可以获取所有用户的图片。
      2. 在静态文件夹中创建名为“upload”或类似名称的文件夹,并将用户的图片上传到该文件夹​​。

      3. 成功上传图片后,将文件名存放在您在上面添加的“pciture”列下的用户表中。

      4. 显示个人资料图片

        1. 当然,您希望使用用户名显示个人资料照片。
        2. 因此,在获取用户的详细信息时,还要从数据库中获取图片名称并以正确的路径显示该图片名称。
        3. 下一步

          1. 用户可以上传大图片作为他们的个人资料图片。因此,为尺寸为100px X 120px的轮廓图片显示500万像素图像并不是一个好主意。因此,在上传时最好重新调整大小并裁剪和存储它,以便节省最终用户的带宽。
          2. 还要确保保留用户的原始图像。在向您的网站添加新功能时,您可能需要稍后使用不同大小的用户图片。
          3. 确保当用户删除其帐户时,也会删除其原始照片。 :)
          4. 您可以使用gd2或ImageMagick。
          5. 希望这会让你对下一步需要了解的内容有所了解。