当文件上传为空时,PHP在mysql表中插入空行

标签 php javascript mysql

我有一个表单,除了文件上传之外,我保留了对其他输入类型的验证,但是如果我不选择任何文件,那么我的脚本会在上传表中添加一个空。有什么方法可以检查用户是否正在上传任何文件,如果有文件,那么我可以运行我的上传脚本...这是脚本

if (isset($_FILES['fileupload'])) {
    $errors     = array();
    $connection = db::factory('mysql');
    $user_id    = $_SESSION['userid'];
    foreach ($_FILES['fileupload']['tmp_name'] as $key => $tmp_name) {
        $file_name = $_FILES['fileupload']['name'][$key];
        $file_size = $_FILES['fileupload']['size'][$key];
        $file_tmp  = $_FILES['fileupload']['tmp_name'][$key];
        $file_type = $_FILES['fileupload']['type'][$key];
        if ($file_size > 2097152) {
            $errors[] = 'File size must be less than 2 MB';
        }
        $upload_dir  = ROOT;
        $desired_dir = ROOT . "/uploads/";
        if (empty($errors) == true) {
            if (is_dir(ROOT . "/uploads/") == false) {
                mkdir(ROOT . "/uploads/", 0700);
            }
            if (is_dir(ROOT . "/uploads/" . $file_name) == false && !file_exists(ROOT . "/uploads/" . $file_name)) {
                $file_path = ROOT . "/uploads/" . $file_name;
                move_uploaded_file($file_tmp, $file_path);
                $full_path = mysql_real_escape_string($file_path);
                $query     = "INSERT INTO uploads (`User_Id`,`File_Name`,`File_Path`,`File_Size`,`File_Type`) VALUES('$user_id','$file_name','$full_path','$file_size','$file_type'); ";
                mysql_query($query);
            } else {
                $new_path = ROOT . "/uploads/" . time() . "_" . $file_name;
                rename($file_tmp, $new_path);
                $file_path = $new_path;
                $full_path = mysql_real_escape_string($file_path);
                $query     = "INSERT INTO uploads (`User_Id`,`File_Name`,`File_Path`,`File_Size`,`File_Type`) VALUES('$user_id','$file_name','$full_path','$file_size','$file_type'); ";
                mysql_query($query);

            }
        } else {
            print_r($errors);
        }
    }
    if (empty($error)) {
        //echo "Success"; exit;
        return true;
    }

    return false;

最佳答案

如果我没记错的话,文件上传字段将在 $_FILES 中创建一个条目,无论它是否为空。在这种情况下,您最好检查 $_FILES['fileupload']['size'][$key] 是否大于零或 $_FILES[' fileupload']['name'][$key] 不为空。

这应该为您表单上上传的每个文件提供答案(即使您有很多文件。)

关于当文件上传为空时,PHP在mysql表中插入空行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18014884/

相关文章:

javascript - onkeyup 函数 JavaScript

javascript - 离开站点时捕获不同类型(onunload)

javascript - 在类生成的 gsp 中显示图像

mysql - rails : Does every http request creates a new connection pool?

mysql - 限制仅在服务器中访问本地地址

PHP - 嵌套输出缓冲

php - 沙盒化用户的 PHP 代码

php - Laravel 删除 X 记录(如果有重复项)的有效方法

javascript - react : Instantiate component once and use multiple times

MySQL优化几何查询