将文件路径保存到Database / SQL

时间:2013-11-11 13:55:44

标签: php mysql sql

INTRO:我正在创建一个“社交网络”网站。这不仅仅是一项学习活动,也不是一项商业活动。 我创建了简单版本的登录和注册(没有加密),他们使用PHPMyadmin并工作。

我已经创建了一个上传图片的表单(稍后会显示)。图片保存到服务器,然后我需要存储数据库的路径...但那就是所有出错的地方!!

每个页面都包含“session_start();”

形式:

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

upload_ppl.php:

<?php
session_start();

$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"] > 2000)
&& 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
      {
          $image_name= $FILES["file"]["name"];
          $path=move_uploaded_file($_FILES["file"]["tmp_name"],
      "upload/" . rand().$_FILES["file"]["name"]);
      echo "Stored in: " . "upload/" . $_FILES["file"]["name"];

      if(mysql_query("INSERT INTO *table* (*column*) VALUES ('$path')")){
          echo "Successfull!!";} else {
            echo 'fail';}
      }
    } 
  }
else
  {
  echo "Invalid file";
  }
?>

请注意,登录时在'connection.page'上建立数据库连接! 我是否需要使用会话变量来执行此操作,只需一起创建一个新连接? 我试过很多次。所有建议都赞赏。谢谢你们!

3 个答案:

答案 0 :(得分:0)

我对你的问题没有直接的答案,但我想分享这个链接(如果你还没有看到它)http://www.developphp.com/list_php_video.php#How_to_Build_a_Social_Network_Website它帮助我几个月前建立了自己的社交网站,我的网站没有完成,但上面网站上的教程确实让我完成了上传图像处理,它工作得很漂亮。

这样做的方式与你做的方式略有不同,但希望如果你没有立即得到解决方案,它可以引导你朝着正确的方向前进。

祝你好运!

答案 1 :(得分:0)

设置一些类似的变量

$folder = "upload/"
$suffix = rand();

更改此行

   $path=move_uploaded_file($_FILES["file"]["tmp_name"],
     "upload/" . rand().$_FILES["file"]["name"]);

 $path=move_uploaded_file($_FILES["file"]["tmp_name"],
      $folder . $suffix . $_FILES["file"]["name"]);

然后你的路径就是,

$fullPath = $folder . $suffix . $_FILES["file"]["name"]);

在您当前的代码下,您无法将文件路径拉出,因为您尚未将其分配给可以抓取和存储的变量。

答案 2 :(得分:0)

你的$路径都错了。 用这个

纠正你的别人
  else
     {
      $image_name = rand().$_FILES["file"]["name"];
      $path = "upload/" . $imagename;
      move_uploaded_file($_FILES["file"]["tmp_name"],$path);

  echo "Stored in: " . $path;

  if(mysql_query("INSERT INTO *table* (*column*) VALUES ('$path')")){
      echo "Successfull!!";} else {
        echo 'fail';}
  }