簡體   English   中英

PHP如何將用戶限制為可以上傳的特定數量的文件

[英]PHP How to limit users to a specific number of files that can be uploaded

我一直在尋找將用戶限制為“ 5”個文件上傳的方法,如果他們上傳更多文件,則回顯一條消息。 我想限制5個,因為為了防止垃圾郵件發送者和想要欺騙系統並將5個以上的文件上傳到他的數據庫中的用戶。 我找到了這個答案

if(isset($_FILES['file']['name'][5])){
  // Code

}else{

  //exit
}

但是,它對我不起作用。 它仍然發送到數據庫,如果文件大於5,則跳過檢查程序。 這是我的代碼

的PHP

 if($_SERVER['REQUEST_METHOD'] =="POST"){


         if(!empty($_POST['price']) && !empty($_POST['description'])){

             if(!ctype_digit($_POST['price'])){

            echo "PRICE ENTERED IS NOT AN INTEGER... PLEASE TRY AGAIN!";
            exit;
        }
            $price = addslashes(trim((int)$_POST['price']));
            $description = addslashes(trim($_POST['description']));
            if(strlen($description) < 15){

                echo "Description field needs to be GREATER than 15 characters!";
                exit;
            }

             if(isset($_FILES['file']['name'][5])){


                 try{

                    // new php data object 
                    $handler = new PDO('mysql:host=127.0.0.1;dbname=magicsever', 'root', '');
                    //ATTR_ERRMODE set to exception
                    $handler->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

                }catch(PDOException $e){
                     die("There was an error connecting to the database");   

                }

                 $query = "INSERT INTO test(name, file)VALUES(:file_name, :file_tmp)";
                 $stmt = $handler->prepare($query);
                 $errors = array();

                 foreach($_FILES['file']['tmp_name'] as $key => $error){

                     if ($error != UPLOAD_ERR_OK) {
                        $errors[] = $_FILES['file']['name'][$key] . ' was not uploaded.';
                        continue;
                    }

                     $file_name = $key.$_FILES['file']['name'][$key];
                     $file_tmp = $_FILES['file']['tmp_name'][$key];

                     try{

                         $stmt->bindParam(':file_name', $file_name, PDO::PARAM_STR);
                         $stmt->bindParam(':file_tmp', $file_tmp, PDO::PARAM_STR);
                         $stmt->execute();

                         $dir = "devFiles";

                         if(is_dir($dir)==false){

                             mkdir($dir, 0700);
                         }

                         if(is_file($dir.'/'.$file_name)==false){

                             move_uploaded_file($file_tmp,$dir.'/'.$file_name);

                         }else{

                            echo '<br><h1 style="color:red;">VALUES MISSING!</h1>';
                            exit;
                         }
                     }catch(PDOException $e){

                         $errors[] = $file_name . 'not saved in db.';
                         echo $e->getMessage();
                     }
                 }

                 echo "pk";
             }else{

                echo "tooo big";
                 exit;
             }

             }else{

             echo '<br><h1 style="color:red;">VALUES MISSING!</h1>';
             exit;

     }



         }

如果執行的代碼超過5個,則您正在執行代碼。要檢查的代碼不超過5個,請使用!

if(!isset($_FILES['file']['name'][5])){

但是您可能只想數:

if(count($_FILES['file']['name']) < 6){

您的條件當前正在檢查是否存在第6個文件,然后繼續。 代替:

if (count($_FILES['file']['name']) <= 5) {
    ...

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM