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

ale*_*ash 4 php sql

有谁知道如何使用PHP上传文件并将文件路径保存到SQL服务器的任何好教程?

Bal*_*usC 12

要上传文件,您至少需要一个带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>
Run Code Online (Sandbox Code Playgroud)

upload.php上传的文件中可以$_FILES使用字段名称作为键访问.

$file = $_FILES['file'];
Run Code Online (Sandbox Code Playgroud)

您可以按如下方式获取其名称:

$name = $file['name'];
Run Code Online (Sandbox Code Playgroud)

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

$path = "/uploads/" . basename($name);
if (move_uploaded_file($file['tmp_name'], $path)) {
    // Move succeed.
} else {
    // Move failed. Possible duplicate?
}
Run Code Online (Sandbox Code Playgroud)

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

$sql = "INSERT INTO file (path) VALUES ('" . mysqli_real_escape_string($path) . "')";
// ...
Run Code Online (Sandbox Code Playgroud)

  • @Col:你对答案进行了贬低和抨击,而不是在答案中详细说明问题.那么,我无法满足你的需求.我是否应该添加错误检查/空检查?那种事.只是说这样而不是咆哮:) (2认同)

Ben*_*Ben 5

来自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>
Run Code Online (Sandbox Code Playgroud)

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
      }
    }
?>
Run Code Online (Sandbox Code Playgroud)

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