Laravel 7 Livewire Login Registration Example Tutorial – onlinecode

Laravel 7 Livewire Login Registration Example Tutorial – onlinecode

In this post we will give you information about Laravel 7 Livewire Login Registration Example Tutorial – onlinecode. Hear we will give you detail about Laravel 7 Livewire Login Registration Example Tutorial – onlinecodeAnd how to use it also give you demo for it if it is necessary.

In this article, we would like to introduce you to how to create a Login Registration Example using Livewire in laravel 7.

So you can create the custom login register page using the below steps.

Overview

Step 1: Install Laravel 7

Step 2: Setting Database Configuration

Step 3: Run Migration Command

Step 4: Install Livewire

Step 5: Create Component

Step 6: Create Route

Step 7: Create Blade Files

Step 8: Run Our Laravel Application

Laravel Livewire Login Register Example Tutorial

Step 1: Install Laravel 7

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

PHP
composer create-project --prefer-dist laravel/laravel laravel7_livewire_login_register

Step 2: Setting Database Configuration

After 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
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=Enter_Your_Database_Name(laravel7_livewire_login_register)
DB_USERNAME=Enter_Your_Database_Username(root)
DB_PASSWORD=Enter_Your_Database_Password(root)

Step 3: Run Migration CommandRun the below command for migratioin of users table.

PHP
php artisan migrate

Step 4: Install LivewireNow, We will install a livewire package using the below command.

composer require livewire/livewire

Step 5: Create ComponentHere below command help to create the component.

php artisan make:livewire LoginRegister

app/Http/Livewire/LoginRegister.php

<?php

namespace AppHttpLivewire;

use LivewireComponent;
use Hash;
use AppUser;

class LoginRegister extends Component
{
    public $users, $email, $password, $name;
    public $registerForm = false;

    public function render()
    {
        return view('livewire.login-register');
    }

    private function resetInputFields(){
        $this->name = '';
        $this->email = '';
        $this->password = '';
    }

    public function login()
    {
        $validatedDate = $this->validate([
            'email' => 'required|email',
            'password' => 'required',
        ]);
        
        if(Auth::attempt(array('email' => $this->email, 'password' => $this->password))){
                session()->flash('message', "You are Login successful.");
        }else{
            session()->flash('error', 'email and password are wrong.');
        }
    }

    public function register()
    {
        $this->registerForm = !$this->registerForm;
    }

    public function registerStore()
    {
        $validatedDate = $this->validate([
            'name' => 'required',
            'email' => 'required|email',
            'password' => 'required',
        ]);

        $this->password = Hash::make($this->password); 

        User::create(['name' => $this->name, 'email' => $this->email,'password' => $this->password]);

        session()->flash('message', 'Your register successfully Go to the login page.');

        $this->resetInputFields();

    }
}
?>

Step 6: Create RouteAdd the following route code in the “routes/web.php” file.

PHP
Route::view('login','livewire.home');

Step 7: Create Blade Files

So finally, first we will open the home.blade.php and login-register.blade.php files and after then paste the following code.resources/views/livewire/home.blade.php

PHP
<!DOCTYPE html>
<html>
<head>
    <title>Laravel 7 Livewire Login Registration Example Tutorial - onlinecode</title>
    <script src="{{ asset('js/app.js') }}" defer></script>
    <link href="{{ asset('css/app.css') }}" rel="stylesheet">
    <script src="//ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
    @livewireStyles
</head>
<body>
    <div >
        <div >
            <div >
                <div >
                    <div ><h5 style="font-size: 23px;">Laravel Livewire - Login Register Example - NiceSnippets.com</h5></div>

                    <div >
                        @livewire('login-register')
                    </div>
                </div>
            </div>
        </div>
    </div>
    @livewireScripts
</script>
</body>
</html>

resources/views/livewire/login-register.blade.php

PHP
<div>
    <div >
        <div >
            @if (session()->has('message'))
                <div >
                    {{ session('message') }}
                </div>
            @endif
            @if (session()->has('error'))
                <div >
                    {{ session('error') }}
                </div>
            @endif
        </div>
    </div>
    @if($registerForm)
        <form>
            <div >
                <div >
                    <div >
                        <label>Name :</label>
                        <input type="text" wire:model="name" >
                        @error('name') <span >{{ $message }}</span>@enderror
                    </div>
                </div>
                <div >
                    <div >
                        <label>Email :</label>
                        <input type="text" wire:model="email" >
                        @error('email') <span >{{ $message }}</span>@enderror
                    </div>
                </div>
                <div >
                    <div >
                        <label>Password :</label>
                        <input type="password" wire:model="password" >
                        @error('password') <span >{{ $message }}</span>@enderror
                    </div>
                </div>
                <div >
                    <button  wire:click.prevent="registerStore">Register</button>
                </div>
                <div >
                    <a  wire:click.prevent="register"><strong>Login</strong></a>
                </div>
            </div>
        </form>
    @else
        <form>
            <div >
                <div >
                    <div >
                        <label>Email :</label>
                        <input type="text" wire:model="email" >
                        @error('email') <span >{{ $message }}</span>@enderror
                    </div>
                </div>
                <div >
                    <div >
                        <label>Password :</label>
                        <input type="password" wire:model="password" >
                        @error('password') <span >{{ $message }}</span>@enderror
                    </div>
                </div>
                <div >
                    <button  wire:click.prevent="login">Login</button>
                </div>
                <div >
                    Don't have account? <a  wire:click.prevent="register"><strong>Register Here</strong></a>
                </div>
            </div>
        </form>
    @endif
</div>

Step 8: Run Our Laravel ApplicationWe can start the server and run this example using the below command.

php artisan serve

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

http://127.0.0.1:8000/login

Read AlsoLaravel 6 CRUD (Create Read Update Delete) Tutorial For Beginners

Laravel 7 CRUD Operation With Ajax Example

Laravel 6 CRUD Operation With Ajax Example

Laravel 6 Pagination Example Tutorial

Laravel 7 Pagination Example Tutorial

Please follow and like us:

Hope this code and post will helped you for implement Laravel 7 Livewire Login Registration Example Tutorial – onlinecode. if you need any help or any feedback give it in comment section or you have good idea about this post you can give it comment section. Your comment will help us for help you more and improve us. we will give you this type of more interesting post in featured also so, For more interesting post and code Keep reading our blogs

For More Info See :: laravel And github

Leave a Comment

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

10  +    =  11

We're accepting well-written guest posts and this is a great opportunity to collaborate : Contact US