Skip to content
Youths Forum Youths Forum Youths Forum

Tech Blogs & Programming Tutorials

Youths Forum Youths Forum Youths Forum

Tech Blogs & Programming Tutorials

  • Blog
  • News
  • Programming
    • PHP
    • JavaScript
    • JQuery
    • CSS
    • HTML
    • API
  • Stock Market Live
  • Automobiles
    • Cars
  • Gadgets
    • Phones
    • Android Phones

Categories

  • Automobiles (12)
    • Cars (7)
  • Blog (103)
    • Poems (2)
    • Space (2)
  • Command (2)
  • Education (2)
  • Entertainment (4)
  • Gadgets (9)
    • Phones (8)
      • Android Phones (4)
  • HTML Templates (11)
  • IT Training Institutes (1)
  • Lifestyle (4)
  • News (51)
  • Others (23)
  • Programming (296)
    • API (16)
    • CSS (83)
    • Database (4)
    • Hosting (1)
    • HTML (37)
    • JavaScript (117)
      • JQuery (27)
      • ReactJS (7)
    • PHP (116)
  • Python (3)
  • recipes (1)
  • SEE Result (1)
  • Server (3)
  • Blog
  • News
  • Programming
    • PHP
    • JavaScript
    • JQuery
    • CSS
    • HTML
    • API
  • Stock Market Live
  • Automobiles
    • Cars
  • Gadgets
    • Phones
    • Android Phones
Close

Search

PHP

Multiple File Upload with HTML and PHP

By Admin
April 7, 2020 2 Min Read
0

We might have been in situation where we need to upload multiple files from a form. If you are in same situation, then you are in right place for the solution. In this article, we are going to learn to upload multiple files with HTML and PHP.

HTML

Firstly, we need to create a HTML form with attribute enctype=’multiple/form-data’. In fact, the enctype attribute specifies how the form-data should be encoded when submitting it to the server. When we are using forms that have a file upload control, weneed to specify enctype as multiple/form-data.

<form action="" method="post" enctype="multipart/form-data">
  <div class="form-group">
    <label>Select Files: </label>
    <input type="file" name="fileUpload[]" multiple > 
  </div>
  <input type="submit" name="Submit" value="Upload" >
</form>

If you have a closer look at the above HTML, we have used multiple attribute for the file input which allows us to select multiple files while uploading. Also, name=”fileUpload[]” allows array of files to be submitted.

Full Source Code :

index.html

<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css" integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">

<style>
  .input-wrapper{
    margin-top: 20px;
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #000;
  }
</style>

<h1 class="text-center" style="margin:20px 20px;">Multiple File Upload with HTML and PHP</h1>
<hr>
<div class="row">
  <div class="offset-md-4 col-md-5">
    <form action="upload.php" method="post" enctype="multipart/form-data">
      <div class="form-group input-container">
        <label>Select Files: </label>
        <input type="file" class="form-control" name="fileUpload[]" multiple > 
      </div>
      
      <input type="submit" class="btn btn-success float-right" name="Submit" value="Upload" >
    </form>
  </div>
</div>

upload.php

<?php
$target_dir = 'files/';
if( isset($_FILES['fileUpload']['name'])) {
      
  $total_files = count($_FILES['fileUpload']['name']);
  $uploaded_files = 0;
  
  for($key = 0; $key < $total_files; $key++) {
    
    if(isset($_FILES['fileUpload']['name'][$key]) && $_FILES['fileUpload']['size'][$key] > 0) {

      $ext = strtolower(pathinfo($_FILES["fileUpload"]["name"][$key], PATHINFO_EXTENSION));
      if(!in_array( $ext, array('jpg', 'jpeg', 'png', 'gif', 'bmp'))) {
        echo 'extenstion not allowed';
        exit;
      }

      $maxFileSize = 5 * 1024 * 1024;
      $errors = array();
      if($_FILES['fileUpload']['size'][$key] > $maxFileSize){
        echo 'File size is greater than allowed size';
        exit;
      }

      
      $original_filename = $_FILES['fileUpload']['name'][$key];
      $target = $target_dir . basename($original_filename);
      $tmp  = $_FILES['fileUpload']['tmp_name'][$key];
      if(move_uploaded_file($tmp, $target)){
        $uploaded_files++;
      }
    }
    
  }
  echo $uploaded_files.' Files Uploaded';
}

 

Tags:

HTMLPHPupload
Author

Admin

Follow Me
Other Articles
Previous

Password Protect Website using .htaccess file

Next

Speech to Text Conversion using JavaScript

No Comment! Be the first one.

Leave a Reply

Your email address will not be published. Required fields are marked *

FIFA World Cup 2026 Predict and Win by SportsGuff

Recent Posts

  • Unpacking Nepal’s Record Rs 2.12 Trillion Budget and What It Means for You
  • How to Write a Strong Scholarship Application: The Ultimate Step-by-Step Guide
  • How to Prepare for Exams Without Stress: The Ultimate Science-Backed Guide
  • Chiranjibi Adhikari Appointed Acting President of CAN Federation
  • How to Design a Student Marksheet Using HTML and CSS

Tags

adsense ai animate animation animation using HTML and CSS API blog calculator chatgpt Cryptocurrency CSS css animation design Email Facebook featured filemanager file manager free template google htaccess HTML image Instagram interview javascript JQuery jquery ui NADA AutoShow NADA Auto Show 2024 password PHP Progressive Web App PWA QR random react reactjs Rotate travel Twitter vpn youthforum youthsforum youtube

About Us

At Youths Forum, we are passionate about sharing knowledge that empowers students, educators, professionals, and technology enthusiasts.

Our Mission

Our mission is simple: to make technology and education accessible, understandable, and beneficial for everyone. We strive to create content that helps our readers learn new skills and stay updated with industry developments.

RSS RSS

  • Unpacking Nepal’s Record Rs 2.12 Trillion Budget and What It Means for You Admin
  • How to Write a Strong Scholarship Application: The Ultimate Step-by-Step Guide Admin
  • How to Prepare for Exams Without Stress: The Ultimate Science-Backed Guide Admin

Quick Links

  • Stock Market Live
  • Parliament Election 2082
Copyright 2026 — Youths Forum. All rights reserved. Blogsy WordPress Theme