Laravel 8 Crud with Image Upload Tutorial
https://laratutorials.com/laravel-8-crud-with-image-upload-tutorial/
Laravel 8 Crud with Image Upload Tutorial
Laravel 8 crud with image upload example tutorial. In this post, i will show you from scratch on how to make simple first crud application in laravel 8 with image upload and validation.
In this example post, i will create blog post crud (create , read, update and delete) app with image upload in laravel 8 and validation.
Laravel 8 CRUD with Image Upload Tutorial
Step 1 – Install Laravel 8 Application
Step 2 – Configuring Database using Env File
Step 3 – Create Post CRUD Model & Migration
Step 4 – Create Post CRUD Routes
Step 5 – Creating Resource Controller
Step 6 – Create POST CRUD Blade Views File
Step 7 – Start Development Server
Step 8 – Run Laravel 8 CRUD with Image Upload App On Browser
Step 1 – Install Laravel 8 Application
In step 1, open your terminal and navigate to your local web server directory using the following command:
Then install laravel 8 latest application using the following command:
Step 2 – Configuring Database using Env File
In step 2, open your downloaded laravel 8 app into any text editor. Then find .env file and configure database detail like following:DB_CONNECTION=mysqlDB_HOST=127.0.0.1DB_PORT=3306DB_DATABASE=db nameDB_USERNAME=db user nameDB_PASSWORD=db password
Step 3 – Create Post CRUD Model & Migration
In step 3, open command prompt and navigate to your project by using the following command:
Then create model and migration file by using the following command:
The above command will create two files into your laravel 8 form validation application, which is located inside the following locations:
Laravel8Crud/app/Models/Post.php
Laravel8Crud/database/migrations/create_posts_table.php
Now, find Post.php model file inside Laravel8Crud/app/Models directory. And open it then add the fillable property code into Post.php file, like following:<?phpnamespace App\Models;use Illuminate\Database\Eloquent\Factories\HasFactory;use Illuminate\Database\Eloquent\Model;class Post extends Model{ use HasFactory; protected $fillable = [ 'title', 'description' ];}
Then, find create_posts_table.php file inside Laravel8Crud/database/migrations/ directory. Then open this file and add the following code into function up() on this file: public function up() { Schema::create('posts', function (Blueprint $table) { $table->id(); $table->string('title'); $table->string('image'); $table->text('description'); $table->timestamps(); }); }
Now, open again your terminal and type the following command on cmd to create tables into your selected database:
Step 4 – Create POST CRUD Routes
In step 4, open your web.php file, which is located inside routes directory. Then add the following routes into web.php file:use App\Http\Controllers\PostCRUDController;Route::resource('posts', PostCRUDController::class);
Step 5 – Creating Resource Controller
In step 5, create resource controller by using the following command:
The above command will create PostCRUDController.php file, which is located inside LaravelForm/app/Http/Controllers/ directory.
The following laravel validation rules will validate form and image file data before store into database in laravel: $request->validate([ 'title' => 'required', 'image' => 'required|image|mimes:jpg,png,jpeg,gif,svg|max:2048', 'description' => 'required', ]);
So open PostCRUDController.php file and add the following code into it:<?phpnamespace App\Http\Controllers;use App\Models\Post;use Illuminate\Http\Request;class PostCRUDController extends Controller{ /** * Display a listing of the resource. * * @return \Illuminate\Http\Response */ public function index() { $data['posts'] = Post::orderBy('id','desc')->paginate(5); return view('posts.index', $data); } /** * Show the form for creating a new resource. * * @return \Illuminate\Http\Response */ public function create() { return view('posts.create'); } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { $request->validate([ 'title' => 'required', 'image' => 'required|image|mimes:jpg,png,jpeg,gif,svg|max:2048', 'description' => 'required', ]); $path = $request->file('image')->store('public/images'); $post = new Post; $post->title = $request->title; $post->description = $request->description; $post->image = $path; $post->save(); return redirect()->route('posts.index') ->with('success','Post has been created successfully.'); } /** * Display the specified resource. * * @param \App\post $post * @return \Illuminate\Http\Response */ public function show(Post $post) { return view('posts.show',compact('post')); } /** * Show the form for editing the specified resource. * * @param \App\post $post * @return \Illuminate\Http\Response */ public function edit(Post $post) { return view('posts.edit',compact('post')); } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param \App\post $post * @return \Illuminate\Http\Response */ public function update(Request $request, $id) { $request->validate([ 'title' => 'required', 'description' => 'required', ]); $post = Post::find($id); if($request->hasFile('image')){ $request->validate([ 'image' => 'required|image|mimes:jpg,png,jpeg,gif,svg|max:2048', ]); $path = $request->file('image')->store('public/images'); $post->image = $path; } $post->title = $request->title; $post->description = $request->description; $post->save(); return redirect()->route('posts.index') ->with('success','Post updated successfully'); } /** * Remove the specified resource from storage. * * @param \App\Post $post * @return \Illuminate\Http\Response */ public function destroy(Post $post) { $post->delete(); return redirect()->route('posts.index') ->with('success','Post has been deleted successfully'); }}
Step 6 – Create POST CRUD Blade Views File
In step 6, create one directory name posts inside resource/views directory. Then create new 3 blade views file that named create.blade.php, edit.blade.php and index.blade.php inside resources/views/posts directory.
The following code will display success and error message in laravel add and edit blog post with image upload forms. So do not forget to add the following code laravel add edit blog posts with image upload forms: @if ($message = Session::get('success')) <div class="alert alert-success"> <p>{{ $message }}</p> </div> @endif @error('title') <div class="alert alert-danger mt-1 mb-1">{{ $message }}</div> @enderror
Don’t worry i have already added the validation error message display code along with each form fields.
So, you can add the following php and html form code into create.blade.php, edit.blade.php and index.blade.php:
posts/create.blade.php<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Add Blog Post Form - Laravel 8 CRUD Tutorial</title> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" ></head><body><div class="container mt-2"><div class="row"> <div class="col-lg-12 margin-tb"> <div class="pull-left mb-2"> <h2>Add New Post</h2> </div> <div class="pull-right"> <a class="btn btn-primary" href="{{ route('posts.index') }}"> Back</a> </div> </div></div> @if(session('status')) <div class="alert alert-success mb-1 mt-1"> {{ session('status') }} </div> @endif<form action="{{ route('posts.store') }}" method="POST" enctype="multipart/form-data"> @csrf <div class="row"> <div class="col-xs-12 col-sm-12 col-md-12"> <div class="form-group"> <strong>Post Title:</strong> <input type="text" name="title" class="form-control" placeholder="Post Title"> @error('title') <div class="alert alert-danger mt-1 mb-1">{{ $message }}</div> @enderror </div> </div> <div class="col-xs-12 col-sm-12 col-md-12"> <div class="form-group"> <strong>Post Description:</strong> <textarea class="form-control" style="height:150px" name="description" placeholder="Post Description"></textarea> @error('description') <div class="alert alert-danger mt-1 mb-1">{{ $message }}</div> @enderror </div> </div> <div class="col-xs-12 col-sm-12 col-md-12"> <div class="form-group"> <strong>Post Image:</strong> <input type="file" name="image" class="form-control" placeholder="Post Title"> @error('image') <div class="alert alert-danger mt-1 mb-1">{{ $message }}</div> @enderror </div> </div> <button type="submit" class="btn btn-primary ml-3">Submit</button> </div></form></body></html>
posts/edit.blade.php<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Edit Blog Post Form - Laravel 8 CRUD Tutorial</title> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" ></head><body><div class="container mt-2"> <div class="row"> <div class="col-lg-12 margin-tb"> <div class="pull-left"> <h2>Edit Post</h2> </div> <div class="pull-right"> <a class="btn btn-primary" href="{{ route('posts.index') }}" enctype="multipart/form-data"> Back</a> </div> </div> </div> @if(session('status')) <div class="alert alert-success mb-1 mt-1"> {{ session('status') }} </div> @endif <form action="{{ route('posts.update',$post->id) }}" method="POST" enctype="multipart/form-data"> @csrf @method('PUT') <div class="row"> <div class="col-xs-12 col-sm-12 col-md-12"> <div class="form-group"> <strong>Post Title:</strong> <input type="text" name="title" value="{{ $post->title }}" class="form-control" placeholder="Post Title"> @error('title') <div class="alert alert-danger mt-1 mb-1">{{ $message }}</div> @enderror </div> </div> <div class="col-xs-12 col-sm-12 col-md-12"> <div class="form-group"> <strong>Post Description:</strong> <textarea class="form-control" style="height:150px" name="description" placeholder="Post Description">{{ $post->description }}</textarea> @error('description') <div class="alert alert-danger mt-1 mb-1">{{ $message }}</div> @enderror </div> </div> <div class="col-xs-12 col-sm-12 col-md-12"> <div class="form-group"> <strong>Post Image:</strong> <input type="file" name="image" class="form-control" placeholder="Post Title"> @error('image') <div class="alert alert-danger mt-1 mb-1">{{ $message }}</div> @enderror </div> <div class="form-group"> <img src="{{ Storage::url($post->image) }}" height="200" width="200" alt="" /> </div> </div> <button type="submit" class="btn btn-primary ml-3">Submit</button> </div> </form></div></body></html>
posts/index.blade.php<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>Laravel 8 CRUD Tutorial</title> <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css" ></head><body><div class="container mt-2"><div class="row"> <div class="col-lg-12 margin-tb"> <div class="pull-left"> <h2>Laravel 8 Post CRUD Tutorial</h2> </div> <div class="pull-right mb-2"> <a class="btn btn-success" href="{{ route('posts.create') }}"> Create New Post</a> </div> </div> </div> @if ($message = Session::get('success')) <div class="alert alert-success"> <p>{{ $message }}</p> </div> @endif <table class="table table-bordered"> <tr> <th>S.No</th> <th>Image</th> <th>Title</th> <th>Description</th> <th width="280px">Action</th> </tr> @foreach ($posts as $post) <tr> <td>{{ $post->id }}</td> <td><img src="{{ Storage::url($post->image) }}" height="75" width="75" alt="" /></td> <td>{{ $post->title }}</td> <td>{{ $post->description }}</td> <td> <form action="{{ route('posts.destroy',$post->id) }}" method="POST"> <a class="btn btn-primary" href="{{ route('posts.edit',$post->id) }}">Edit</a> @csrf @method('DELETE') <button type="submit" class="btn btn-danger">Delete</button> </form> </td> </tr> @endforeach </table> {!! $posts->links() !!}</body></html>
Step 7 – Start Development Server
Before start development server, open command prompt type the following command:
Then, type the following command on cmd to start development server for your simple laravel 8 crud with image upload app:
Step 8 – Run Laravel 8 CRUD with Image Upload App On Browser
In step 8, open your browser and fire the following url into your browser:
Last updated