Skip to content
  • About Us
  • Contact Us
  • Privacy Policy
  • Terms & Conditions
  • Site Map

XpertPhp

Expertphp Is The Best Tutorial For Beginners

  • Home
  • Javascript
    • Jquery
    • React JS
    • Angularjs
    • Angular
    • Nodejs
  • Codeigniter
  • Laravel
  • Contact Us
  • About Us
  • Live Demos
Laravel 9 Summernote Image Upload With Example

Laravel 9 Summernote Image Upload With Example

Posted on March 6, 2022May 1, 2022 By XpertPhp

Today, We will explain to you how to image upload with summernote example in laravel 9. Summernote editor is one type of WYSIWYG HTML editors like CKEditor.

When we need to store long text, article content, product summary, and different tag content with the description in our database we use the WYSIWYG HTML editors.

Read Also: Laravel 9 integrate summernote with example

The WYSIWYG editor free to install our laravel application. let’s follow the below example of Laravel Summernote Image Upload.

Overview

Step 1: Install Laravel

Step 2: Setting Database Configuration

Step 3: Create Table using migration

Step 4: Create Route

Step 5: Create a Model and Controller

Step 6: Create Blade Files

Step 7: Run Our Laravel Application

Laravel 9 Summernote Image Upload With Example

Step 1: Install Laravel

We are going to install laravel 9, so first open the command prompt or terminal and go to xampp htdocs folder directory using the command prompt. after then run the below command.

PHP
1
composer create-project --prefer-dist laravel/laravel laravel9_imageupload_summernote

Step 2: Setting Database Configuration

After the complete installation of laravel. we have to database configuration. now we will open the .env file and change the database name, username, password in the .env file. See below changes in a .env file.

PHP
1
2
3
4
5
6
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=Enter_Your_Database_Name(laravel9_imageupload_summernote)
DB_USERNAME=Enter_Your_Database_Username(root)
DB_PASSWORD=Enter_Your_Database_Password(root)

Step 3: Create Table using migration

Now, We need to create a migration. so we will below command using create the articles table migration.

PHP
1
php artisan make:migration create_articles_table --create=articles

After complete migration. we need below changes in the database/migrations/create_articles_table file.

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<?php
 
use Illuminate\Support\Facades\Schema;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Database\Migrations\Migration;
 
class CreateArticlesTable extends Migration
{
    /**
     * Run the migrations.
     *
     * @return void
     */
    public function up()
    {
        Schema::create('articles', function (Blueprint $table) {
            $table->bigIncrements('id');
            $table->string('title');
            $table->longText('description');
            $table->string('author_name');
            $table->timestamps();
        });
    }
 
    /**
     * Reverse the migrations.
     *
     * @return void
     */
    public function down()
    {
        Schema::dropIfExists('articles');
    }
}
?>

Run the below command. after the changes above file.

PHP
1
php artisan migrate

Step 4: Create Route

Add the following route code in the “routes/web.php” file.

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php
use App\Http\Controllers\ArticleController;
 
/*
|--------------------------------------------------------------------------
| Web Routes
|--------------------------------------------------------------------------
|
| Here is where you can register web routes for your application. These
| routes are loaded by the RouteServiceProvider within a group which
| contains the "web" middleware group. Now create something great!
|
*/
Route::get('/', function () {
   // return view('welcome');
});
 
Route::get('/article',[ArticleController::class, 'index'])->name('article.form');
 
Route::post('/save-article',[ArticleController::class, 'storeArticle'])->name('store.article');
 
Route::get('/article/{id}',[ArticleController::class, 'showArticle'])->name('show.article');
?>

Step 5: Create a Model and Controller

Here below command help to create the controller and model.

PHP
1
php artisan make:controller ArticleController --resource --model=Article

Article.php

PHP
1
2
3
4
5
6
7
8
9
10
11
12
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class Student extends Model
{
     use HasFactory;
     protected $fillable = [
        'title','description', 'author_name'
    ];
}
?>

ArticleController.php

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<?php
namespace App\Http\Controllers;
use App\Models\Article;
use Illuminate\Http\Request;
use Response;
class ArticleController extends Controller
{
    public function index()
    {
        return view('article-form');
    }
    public function storeArticle(Request $request)
    {
  $this->validate($request, [
            'title' => 'required',
            'description' => 'required',
            'author' => 'required',
        ]);
 
        $description=$request->input('description');
        $dom = new \DomDocument();
        $dom->loadHtml($description, LIBXML_HTML_NOIMPLIED | LIBXML_HTML_NODEFDTD);    
        $images = $dom->getElementsByTagName('img');
 
        foreach($images as $key => $img){
            $data = $img->getAttribute('src');
 
            list($type, $data) = explode(';', $data);
            list(, $data)      = explode(',', $data);
            $data = base64_decode($data);
 
            $image_name= "/upload/" . time().$key.'.png';
            $path = public_path() . $image_name;
 
            file_put_contents($path, $data);
            
            $img->removeAttribute('src');
            $img->setAttribute('src', $image_name);
        }
 
        $description = $dom->saveHTML();
 
        dd($description);
//you can save data into database using below example.
$article = new Article();    
$article->title = $request->input('title');
$article->description =$description;
$article->author =$request->input('author');
$article->save();
return redirect()->route('article.form)->withSuccess(['Data saved successfully.']);
    }
  
    public function showArticle(Request $request, $id)
    {
      $article = Article::where('id',$id)->first();
      return view('display-article', compact('article'));
    }
}
?>

Step 6: Create Blade Files

Finally, We will create the article-form.blade.php file in the “resources/views/” folder directory and paste the below code.

article-form.blade.php

PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
<!DOCTYPE html>
<html lang="en">
<head>
    <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" rel="stylesheet">
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/js/bootstrap.min.js" type="text/javascript"></script>
    <!-- include summernote css/js-->
    <link href="//cdnjs.cloudflare.com/ajax/libs/summernote/0.8.4/summernote.css" rel="stylesheet"
    <script src="//cdnjs.cloudflare.com/ajax/libs/summernote/0.8.4/summernote.js"></script>
</head>
<body>
    <div class="container">
        <div class="row">
            <div class="col-md-12">
                <h1 class="text-center">Laravel 9 integrate summernote with example - XpertPhp</h1><br>
                <form method="post" class="form form-horizontal" action="{{ route('article.form') }}">              
                    <div class="form-group">
                        <label>Title</label>
                        <input type="text" name="title" class="form-control"/>
                    </div>  
                    <div class="form-group">
                        <label>Description</label>
                        <textarea name="description" rows="5" cols="40" class="form-control summernote"></textarea>
                    </div>  
                    <div class="form-group">
                        <label>Author Name</label>
                        <input type="text" name="author" class="form-control"/>
                    </div>  
                    <div class="form-group">
                        <input type="submit" value="Submit" class="btn btn-primary"/>
                    </div>
                </form>            
            </div>
        </div>
    </div>
<script>
$(document).ready(function() {
$('.summernote').summernote();
});
</script>
</body>
</html>

display-article.blade.php

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<!DOCTYPE html>
<html lang="en">
  <head>
    <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" rel="stylesheet">
  </head>
  <body>
    <div class="container">
      <div class="row">
        <div class="col-md-12">
          <h1 class="text-center">Laravel 9 integrate TinyMCE with example - XpertPhp</h1><br>
          </div>
      </div>
      <div class="col-md-12">
        <p>Title: <?php echo $article->title; ?></p>
      </div>
      <div class="col-md-12">
        <p>Description: </p>
        <?php echo $article->description; ?>
      </div>
      <div class="col-md-12">
        <p>Author Name: <?php echo $article->author; ?></p>
      </div>
    </div>
  </body>
</html>

Step 7: Run Our Laravel Application
We can start the server and run this example using the below command.

1
php artisan serve

Now we will run our example using the below Url in the browser.

1
http://127.0.0.1:8000/article

We can start the server and run this example using the below command.

Please follow and like us:
error
fb-share-icon
Tweet
fb-share-icon

Recommended Posts:

  • allow only numbers in textbox javascript onkeypress
  • confirm password validation example in html5
  • how to get textbox value in javascript
  • JavaScript String replace() Method
  • How to Check If Value Exists in a Javascript Array
Javascript Tags:laravel 9 example, laravel 9 tutorial

Post navigation

Previous Post: Laravel 9 Stripe Payment Gateway Integrate Example
Next Post: Laravel 9 CKeditor Image Upload With Example

Categories

  • Ajax
  • Angular
  • Angularjs
  • Bootstrap
  • Codeigniter
  • Css
  • Htaccess
  • Javascript
  • Jquery
  • Laravel
  • MongoDB
  • MySql
  • Nodejs
  • Php
  • React JS
  • Shopify Api
  • Ubuntu

Tags

angular 10 tutorial angular 11 ci tutorial codeigniter 4 image upload Codeigniter 4 Tutorial codeigniter tutorial CodeIgniter tutorial for beginners codeigniter with mysql crud operation eloquent relationships file upload File Validation form validation Image Upload jQuery Ajax Form Handling jquery tricks jquery tutorial laravel 6 Laravel 6 Eloquent Laravel 6 Model laravel 6 relationship laravel 6 relationship eloquent Laravel 6 Routing laravel 7 Laravel 7 Eloquent laravel 7 routing laravel 7 tutorial Laravel 8 laravel 8 example laravel 8 tutorial laravel 9 example laravel 9 tutorial Laravel Framework laravel from scratch Laravel Socialite laravel social login nodejs pagination payment gateway php with mysql react js tutorial rewrite rule send mail validation wysiwyg editor

Latest Posts

  • How to Convert Date and Time from one timezone to another in php
  • how to get current date and time in php
  • Drag and Drop Reorder Items with jQuery, PHP & MySQL
  • Laravel 9 Toastr Notifications Example Tutorial
  • Laravel 9 CRUD Operation Example Using Google Firebase
  • Laravel 9 CKeditor Image Upload With Example
  • Laravel 9 Summernote Image Upload With Example
  • Laravel 9 Stripe Payment Gateway Integrate Example
  • How To Send Email Using Mailtrap In Laravel 9
  • Laravel 9 Fullcalendar Ajax Example Tutorial

Tools

  • Compound Interest Calculator
  • Hex to RGB Color Converter
  • Pinterest Video Downloader
  • Age Calculator Online
  • Convert JSON to PHP Array Online
  • JavaScript Minifier
  • CSS Beautifier
  • CSS Minifier
  • JSON Beautifier
  • JSON Minifier

Copyright © 2018 - 2022,

All Rights Reserved Powered by XpertPhp.com