How to upload multiple Image in Laravel 6

How to upload multiple Image in Laravel 6

In this tutorial, you'll learn how to multiple image upload in Laravel 6. We will upload multiple image with validation in Laravel 6. We will use laravel image validation and store to folder and database for Laravel 6 multiple image upload.

Originally published at https://itsolutionstuff.com

We will create simple multiple image upload in Laravel 6. So you basically use this code on your Laravel 6 application.

We are going from starch so, we will upload multiple file and store on server then after we will store database too. So in this example we will create "files" table using Laravel migration and write code for route, controller and view step by step.

So here you have to just follow bellow step to create Laravel 6 multiple File Upload with Validation Example.

Step 1: Download Laravel 6

In the first step, we will download a new simple copy source code of Laravel App project by typing the some following command.

composer create-project --prefer-dist laravel/laravel blog

Step 2: Add Migration and Model

Here, we need create database migration for files table and also we will create model for files table.

php artisan make:migration create_files_table

Migration:

<?php

use Illuminate\Support\Facades\Schema; use Illuminate\Database\Schema\Blueprint; use Illuminate\Database\Migrations\Migration;

class CreateFormsTable extends Migration { public function up() { Schema::create('files', function (Blueprint $table) { $table->increments('id'); $table->string('filenames'); $table->timestamps(); }); }

public function down()
{
    Schema::dropIfExists('files');
}

} php artisan migrate

now we will create File model by using following command:

php artisan make:model File

Read Also: Laravel 6 CRUD Application Tutorial

Step 3: Create Routes

In third step, we will create routes for multiple file upload. so create two route with GET and POST route example.

routes/web.php

Route::get('file','[email protected]');
Route::post('file','[email protected]');

Step 4: Create Controller

Now we require to add new FileController controller for manage route So let's create FileController with create and store method. Make sure you need to create "files" folder in your public directory.

app/Http/Controllers/FileController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

class FileController extends Controller { /** * Show the application dashboard. * * @return \Illuminate\Http\Response */ public function create() { return view('create'); }

/**
 * Show the application dashboard.
 *
 * @return \Illuminate\Http\Response
 */
public function store(Request $request)
{

    $this-&gt;validate($request, [
            'filenames' =&gt; 'required',
            'filenames.*' =&gt; 'mimes:doc,pdf,docx,zip'
    ]);

    if($request-&gt;hasfile('filenames'))
     {
        foreach($request-&gt;file('filenames') as $file)
        {
            $name = time().'.'.$file-&gt;extension();
            $file-&gt;move(public_path().'/files/', $name);  
            $data[] = $name;  
        }
     }

     $file= new File();
     $file-&gt;filenames=json_encode($data);
     $file-&gt;save();

    return back()-&gt;with('success', 'Data Your files has been successfully added');
}

}

Step 5: Create Blade File

in this step we need to create create.blade.php file in resources folder. So let's create file:

resources/views/create.blade.php

Read Also: Laravel 6 Ajax CRUD Tutorial

<html lang="en">
<head>
  <title>Laravel 6 Multiple File Upload Example</title>
  <script src="jquery/1.9.1/jquery.js"></script>
  <link rel="stylesheet" href="3.3.6/css/bootstrap.min.css">
</head>
<body>

<div class="container lst">

@if (count($errors) > 0) <div class="alert alert-danger"> <strong>Sorry!</strong> There were more problems with your HTML input.<br><br> <ul> @foreach ($errors->all() as $error) <li>{{ $error }}</li> @endforeach </ul> </div> @endif

@if(session('success')) <div class="alert alert-success"> {{ session('success') }} </div> @endif

<h3 class="well">Laravel 6 Multiple File Upload</h3> <form method="post" action="{{url('file')}}" enctype="multipart/form-data"> {{csrf_field()}}

&lt;div class="input-group hdtuto control-group lst increment" &gt;
  &lt;input type="file" name="filenames[]" class="myfrm form-control"&gt;
  &lt;div class="input-group-btn"&gt; 
    &lt;button class="btn btn-success" type="button"&gt;&lt;i class="fldemo glyphicon glyphicon-plus"&gt;&lt;/i&gt;Add&lt;/button&gt;
  &lt;/div&gt;
&lt;/div&gt;
&lt;div class="clone hide"&gt;
  &lt;div class="hdtuto control-group lst input-group" style="margin-top:10px"&gt;
    &lt;input type="file" name="filenames[]" class="myfrm form-control"&gt;
    &lt;div class="input-group-btn"&gt; 
      &lt;button class="btn btn-danger" type="button"&gt;&lt;i class="fldemo glyphicon glyphicon-remove"&gt;&lt;/i&gt; Remove&lt;/button&gt;
    &lt;/div&gt;
  &lt;/div&gt;
&lt;/div&gt;

&lt;button type="submit" class="btn btn-success" style="margin-top:10px"&gt;Submit&lt;/button&gt;

</form>
</div>

<script type="text/javascript"> $(document).ready(function() { $(".btn-success").click(function(){ var lsthmtl = $(".clone").html(); $(".increment").after(lsthmtl); }); $("body").on("click",".btn-danger",function(){ $(this).parents(".hdtuto control-group lst").remove(); }); }); </script>

</body> </html>

Now you can simple run and check it.

I hope it can help you...

Thanks for reading

If you liked this post, share it with all of your programming buddies!

Follow me on Facebook | Twitter

Further reading

What’s New in Laravel 6.0

Laravel 6 CRUD Application Tutorial

Laravel 6 Image Upload Tutorial

Laravel 6 Authentication Tutorial


laravel php image web-development

What's new in Bootstrap 5 and when Bootstrap 5 release date?

How to Build Progressive Web Apps (PWA) using Angular 9

What is new features in Javascript ES2020 ECMAScript 2020

Deno Crash Course: Explore Deno and Create a full REST API with Deno

How to Build a Real-time Chat App with Deno and WebSockets

Convert HTML to Markdown Online

HTML entity encoder decoder Online

Random Password Generator Online

HTML Color Picker online | HEX Color Picker | RGB Color Picker

PHP Web Application Development Company

As a top **PHP Web Application Development Company in USA**[https://www.dataeximit.com/php-development-services/](https://www.dataeximit.com/php-development-services/ "https://www.dataeximit.com/php-development-services/"), we at Data EximIT have...

Advantages of Hiring PHP Developer for your Website Project

PHP - Hypertext pre-processor, a scripting language used by many people in developing web pages, but most of us are unaware even of the full form. To train someone and make them learn this whole language is as difficult and time-consuming as it is...

Hire PHP Developer and Web Developer for your Online Business

PHP is widely used open-source scripting language it helps in making dynamically easy your websites and web application. Mobiweb Technology is your best technical partner and offering you solution for any kind of website and application...

Top Laravel Development Companies Reviews

Among the list of Best Laravel development companies, TopDevelopers has chosen the most acclaimed laravel developers for the visitors so as to make them avail the extremely wonderful service ever offered. The web development companies listed here...

Hire Dedicated eCommerce Web Developers | Top eCommerce Web Designers

Build your eCommerce project by hiring our expert eCommerce Website developers. Our Dedicated Web Designers develop powerful & robust website in a short span of time.