【发布时间】:2010-05-21 02:41:26
【问题描述】:
有没有人知道如何使用php上传文件并将文件路径保存到sql server的任何好的教程?
【问题讨论】:
有没有人知道如何使用php上传文件并将文件路径保存到sql server的任何好的教程?
【问题讨论】:
要上传文件,您至少需要一个带有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) . "')";
// ...
【讨论】:
$path = "/uploads/" 对于新手开发人员来说是非常常见的错误。在真实环境中,文件系统根目录中几乎不可能有上传目录。很可能会与文档根目录混淆。
mysql_real_escape_string 自 PHP 5.5.0 起已已弃用,将来将被删除。请改用mysqli_real_escape_string。
来自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
}
}
?>
请注意,要上传文件,您需要指定保存文件的路径。如果您保存文件,您已经知道它的路径。
【讨论】: