IT/PHP

Laravel 8 - CRUD(7)

Sungjun_ 2021. 1. 7. 16:02

로그인

resources/views/layouts/app.blade.php 파일을 열어서 로그인 버튼을 만듭니다.

<!doctype html>
<html lang="kr">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <link href="{{ asset('css/app.css') }}" rel="stylesheet">
    <title>@yield('title', 'CRUD')</title>
</head>
<body>
@section('header')
    <header class="w-2/3 mx-auto mt-16 text-right">
        <a href="{{route('boards.index')}}" class="text-xl">게시판</a>
        <a href="{{route('auth.register.index')}}" class="text-xl">회원가입</a>
        <a href="{{route('auth.login.index')}}" class="text-xl">로그인</a>
    </header>
@show

@section('section')
@show
</body>
</html>

 

resources/views/auth 폴더 안에 login.blade.php 파일을 만듭니다.

@extends('layouts.app')

@section('section')
    <div class="w-2/3 mx-auto mt-16">
        <form action="/auth/login" method="post" class="w-1/2 mx-auto">
            @csrf
            <p>
                <label for="email" class="pr-2">이메일</label>
                <input type="email" id="email" name="email"
                       class="outline-none border border-blue-400 rounded-lg pl-1 w-1/3">
            </p>
            <p class="mt-4">
                <label for="password" class="pr-2">비밀번호</label>
                <input type="password" id="password" name="password"
                       class="outline-none border border-blue-400 rounded-lg pl-1 w-1/3">
            </p>
            <p class="mt-8">
                <input type="submit" value="로그인"
                       class="bg-blue-500 hover:bg-blue-700 px-4 py-1 text-lg text-white rounded-lg outline-none">
                <input type="button" class="bg-red-500 hover:bg-red-700 px-4 py-1 ml-4 text-lg text-white rounded-lg outline-none"
                       value="취소" onclick="window.location.href ='{{route('home')}}'">
            </p>
        </form>
    </div>
@stop

 

php artisan make:controller LoginController로 컨트롤러를 만들어줍니다.

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

class LoginController extends Controller
{
    public function index(){
        return view('auth.login');
    }

    public function login(Request $request){
        $loginInfo = $request -> only(['email', 'password']);
        if(auth() -> attempt($loginInfo)){
            return redirect() -> route('home');
        } else{
            return redirect() -> route('auth.login.index');
        }

    }

    public function logout(){
        auth() -> logout();
        
        return redirect() -> route('home');
    }
}

 

$loginInfo에 이메일과 패스워드 정보를 저장하고

성공했을 시에는 메인화면으로, 실패했을 시에는 로그인화면으로 가게했습니다.

로그아웃도 메인화면으로 가게했습니다.

 

web.php에 라우트를 설정해줍니다.

<?php

use Illuminate\Support\Facades\Route;
use App\Http\Controllers\BoardController;
use App\Http\Controllers\RegisterController;
use App\Http\Controllers\LoginController;

Route::get('/', function () {
    return view('home');
}) -> name('home');

Route::get('auth/register', [RegisterController::class, 'index']) -> name('auth.register.index');
Route::post('auth/register', [RegisterController::class, 'store']) -> name('auth.register.store');

Route::get('auth/login', [LoginController::class, 'index']) -> name('auth.login.index');
Route::post('auth/login', [LoginController::class, 'login']) -> name('auth.login.attempt');
Route::post('auth/logout', [LoginController::class, 'logout']) -> name('auth.logout');

Route::get('boards', [BoardController::class, 'index']) -> name('boards.index');
Route::get('boards/create', [BoardController::class, 'create']) -> name('boards.create');
Route::post('boards', [BoardController::class, 'store']) -> name('boards.store');
Route::get('boards/{board}', [BoardController::class, 'show']) -> name('boards.show');
Route::get('boards/{board}/edit', [BoardController::class, 'edit']) -> name('boards.edit');
Route::put('boards/{board}', [BoardController::class, 'update']) -> name('boards.update');

 

이제 제대로 로그인이 됐는지 확인하기 위해 resources/views/layouts/app.blade.php 파일을 수정하겠습니다.

<!doctype html>
<html lang="kr">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <link href="{{ asset('css/app.css') }}" rel="stylesheet">
    <title>@yield('title', 'CRUD')</title>
</head>
<body>
@section('header')
    <header class="w-2/3 mx-auto mt-16 text-right">
        <a href="{{route('boards.index')}}" class="text-xl">게시판</a>
        @guest()
            <a href="{{route('auth.register.index')}}" class="text-xl">회원가입</a>
            <a href="{{route('auth.login.index')}}" class="text-xl">로그인</a>
        @endguest

        @auth()
            <span class="text-xl text-blue-500">{{auth() -> user() -> name}}</span>
            <form action="/auth/logout" method="post" class="inline-block">
                @csrf
                <a href="{{route('auth.logout')}}"><button class="text-xl">로그아웃</button></a>
            </form>
        @endauth
    </header>
@show

@section('section')
@show
</body>
</html>

 

@guset와 @auth를 사용하면 미인증 사용자와 인증 사용자를 나눌 수 있습니다.

로그인하지 않을 경우에는 회원가입과 로그인을

로그인 했을 경우에는 사용자 이름과 로그아웃 버튼이 보이게 했습니다.

 

로그인 해서 실험 해보면 확인할 수 있습니다.

 

로그인
로그아웃