用php上传文件并将路径保存到sql

Posted

技术标签:

【中文标题】用php上传文件并将路径保存到sql【英文标题】:upload file with php and save path to sql 【发布时间】:2010-05-21 02:41:26 【问题描述】:

有没有人知道如何使用php上传文件并将文件路径保存到sql server的任何好的教程?

【问题讨论】:

【参考方案1】:

要上传文件,您至少需要一个带有multipart/form-data 编码的 html POST 表单。在其中放置一个 input type="file" 字段来浏览文件和一个提交按钮来提交表单。

<form action="upload.php" method="post" enctype="multipart/form-data">
    <input type="file" name="file">
    <input type="submit">
</form>

upload.php 中,上传的文件可由$_FILES 访问,字段名称为键。

$file = $_FILES['file'];

你可以得到它的名字如下:

$name = $file['name'];

您需要使用move_uploaded_file() 将其移动到永久位置,否则它会丢失:

$path = "/uploads/" . basename($name);
if (move_uploaded_file($file['tmp_name'], $path)) 
    // Move succeed.
 else 
    // Move failed. Possible duplicate?

您可以按照通常的方式将路径存储在数据库中:

$sql = "INSERT INTO file (path) VALUES ('" . mysqli_real_escape_string($path) . "')";
// ...

【讨论】:

@Col:你对答案投了反对票和咆哮,而不是在答案中详细说明问题。好吧,那我不能做太多的事情来满足你。我是否应该添加错误检查/空检查?那种东西。就这么说吧,而不是咆哮:) $path = "/uploads/" 对于新手开发人员来说是非常常见的错误。在真实环境中,文件系统根目录中几乎不可能有上传目录。很可能会与文档根目录混淆。 @Col:我通常使用专用/托管在我可以完全控制文件系统的地方。这也是 Java webapps 中的正常做法,但对于普通的 PHP webapp/hosting,你确实是对的。 只是好奇,什么操作系统让你上传到根文件夹?我唯一知道的是窗户。但是将目录直接放置在应用程序目录之外的根文件夹中仍然是不好的设计,不是吗? mysql_real_escape_string 自 PHP 5.5.0 起已已弃用,将来将被删除。请改用mysqli_real_escape_string【参考方案2】:

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

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>

PHP

<?php
  if ($_FILES["file"]["error"] > 0)
    
    echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
    
  else
       
    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"]; //<- This is it
      
    
?>

请注意,要上传文件,您需要指定保存文件的路径。如果您保存文件,您已经知道它的路径。

【讨论】:

以上是关于用php上传文件并将路径保存到sql的主要内容,如果未能解决你的问题,请参考以下文章

如何使用 PHP 以动态形式上传文件并将路径/文件名与其他数据一起保存到 mysql

sql查询不更新img文件路径

DreamFactory:如何将图像上传到文件服务器并将图像的路径保存在数据库中?

ExpressJS:TypeError:无法读取未定义的属性“路径”尝试将文件上传到 cloudinary 并将 url 保存到 mongoDB

在 PHP 中创建文件并将其上传到 FTP 服务器而不在本地保存

怎样用php实现上传图片到数据库