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.
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
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:
<?phpuse 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
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’,‘FileController@create’);
Route::post(‘file’,‘FileController@store’);
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
<?phpnamespace 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->validate($request, [ 'filenames' => 'required', 'filenames.*' => 'mimes:doc,pdf,docx,zip' ]); if($request->hasfile('filenames')) { foreach($request->file('filenames') as $file) { $name = time().'.'.$file->extension(); $file->move(public_path().'/files/', $name); $data[] = $name; } } $file= new File(); $file->filenames=json_encode($data); $file->save(); return back()->with('success', 'Data Your files has been successfully added'); }
}
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()}}<div class="input-group hdtuto control-group lst increment" > <input type="file" name="filenames[]" class="myfrm form-control"> <div class="input-group-btn"> <button class="btn btn-success" type="button"><i class="fldemo glyphicon glyphicon-plus"></i>Add</button> </div> </div> <div class="clone hide"> <div class="hdtuto control-group lst input-group" style="margin-top:10px"> <input type="file" name="filenames[]" class="myfrm form-control"> <div class="input-group-btn"> <button class="btn btn-danger" type="button"><i class="fldemo glyphicon glyphicon-remove"></i> Remove</button> </div> </div> </div> <button type="submit" class="btn btn-success" style="margin-top:10px">Submit</button>
</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
☞ Laravel 6 CRUD Application Tutorial
☞ Laravel 6 Image Upload Tutorial
☞ Laravel 6 Authentication Tutorial
#laravel #php #image #web-development