我的上传文件脚本如何将文件路径保存到数据库,返回错误消息并创建文件夹?
Posted
技术标签:
【中文标题】我的上传文件脚本如何将文件路径保存到数据库,返回错误消息并创建文件夹?【英文标题】:How can my upload file script save file path to the database, return an error message, and create a folder? 【发布时间】:2014-12-06 17:58:12 【问题描述】:我正在制作一个脚本来上传文件。我有一些问题。
我正在使用the dropzonejs library。
我需要将上传的文件信息保存到数据库中。我做了一个准备好的声明,但它不起作用:表中没有存储任何内容。
表信息:userID (int 11)、image_name (varchar 50)、image_path (varchar 60)、up_time (varchar 60)、up_ip (varchar 45)。
在哪里可以看到 mysql 错误?我已经检查了 appdata 中的 .err 文件,但那里什么也没有。
如何将$error_msg
从上传页面返回到表单页面?我必须将第一个检查(文件存在)从上传页面移动到 dropzone.js 文件,但我不确定如何执行此操作。也许已经有一个选项,但我搜索并没有找到。
html:
<link rel="stylesheet" href="/css/dropzone.css"/>
<script type="text/javascript" src="/js/dropzone.js"></script>
<form action="/upload"
class="dropzone"
id="my-awesome-dropzone"></form>
<?php
if (isset($error_msg))
echo '<p class="error">' . $error_msg . '</p>';
?>
我的 upload.php 脚本:
require_once('/includes/functions.php');
$image = basename($_FILES['file']['name']);
$image = str_replace(' ','|',$image);
$img_dir = $_SERVER['DOCUMENT_ROOT'] . '/images/user_uploads/' . $_SESSION['username'] . '/';
if (file_exists($img_dir . $image))
return $error_msg = $img_dir . $_FILES["file"]["name"] . " ya existe. ";
elseif (move_uploaded_file($_FILES["file"]["tmp_name"],
$img_dir . $image))
$img_path = $img_dir . $image;
$up_time = get_current_time();
$up_ip = get_ip_address();
if ($insert_stmt = $mysqli->prepare("INSERT INTO user_uploads (userID, image_name, image_path, up_time, up_ip) VALUES (?, ?, ?, ?, ?)"))
$insert_stmt->bind_param('issss', $_SESSION['user_id'], $_FILES["file"]["name"], $img_path, $up_time, $up_ip);
if (! $insert_stmt->execute())
return $error_msg = '¡Error al subir la imagen! (db_error)';
else return $error_msg = '¡Error al subir la imagen!';
这只有在我使用$_SERVER['DOCUMENT_ROOT']
作为图像目录时才有效。
-
如果文件夹不存在(每个用户都有自己的上传文件夹),我如何告诉脚本自动创建它?
我在 Windows 中使用 XAMPP,但一旦完成,我会将其上传到 Linux 主机,所以也许我必须更改路径或其他东西。那么这两种操作系统有什么区别呢?
【问题讨论】:
这确实是三个独立的问题,应该这样问。 对不起,我认为只发布 1 次会更好,但我已经回答了。感谢您的更正。 【参考方案1】:好的,我明白了:)
$tmp_name = $_FILES["file"]["tmp_name"];
$image = basename($_FILES['file']['name']);
$image = str_replace(' ', '|', $image);
$img_dir = $_SERVER['DOCUMENT_ROOT'] . '/images/user_uploads/' . $_SESSION['username'] . '/';
if (!file_exists($_SERVER['DOCUMENT_ROOT'] . '/images/user_uploads/' . $_SESSION['username']))
mkdir($_SERVER['DOCUMENT_ROOT'] . '\\images\\user_uploads\\' . $_SESSION['username']);
move_uploaded_file($tmp_name, $img_dir . $image);
$img_path = $_SESSION['username'] . '/' . $image;
$up_time = get_current_time();
$up_ip = get_ip_address();
if ($stmt = $mysqli->prepare("INSERT INTO user_uploads (userID, image_name, image_path, up_time, up_ip) VALUES (?, ?, ?, ?, ?)"))
$stmt->bind_param('issss', $_SESSION['user_id'], $image, $img_path, $up_time, $up_ip);
$stmt->execute();
使用这个 javascript,我认为只能从 javascript 本身返回错误消息,因此创建函数或设置消息就可以了:
dictInvalidFileType: "No puedes subir este tipo de archivos.",
dictResponseError: "Código de error statusCode.",
希望它可以帮助某人:)
【讨论】:
【参考方案2】:-
请提供您的最终查询及其值
您在一个文件中上传代码,因此您无法通过包含文件返回值,您需要将该代码包装在函数或类方法中。
请参考:Create a folder if it doesn't already exist
【讨论】:
最终查询和它的值是什么意思?什么将被发送到 MySQL?所以,我必须创建一个函数并将两个变量发送给它: $_FILES['file']['name'] 和 $_FILES['file']['tempname'] 对吗?以上是关于我的上传文件脚本如何将文件路径保存到数据库,返回错误消息并创建文件夹?的主要内容,如果未能解决你的问题,请参考以下文章
DreamFactory:如何将图像上传到文件服务器并将图像的路径保存在数据库中?