Edited at

【laravel5.8】 authで作成したログイン画面のバリデーションエラーの表示方法を変更

authで作成したログイン周りのバリデーションで、HTML5のバリデーションを使いたくない場合。


HTML5のバリデーションを無効にする


resources/views/auth/login.blade.php

@extends('layouts.app')

@section('content')
<div class="container">
<div class="row justify-content-center">
<div class="col-md-8">
<div class="card">
<div class="card-header">{{ __('Login') }}</div>

<div class="card-body">
{{-- novalidateを追加 --}}
{{-- <form method="POST" action="{{ route('login') }}">--}}
<form method="POST" action="{{ route('login') }}" novalidate>
@csrf

<div class="form-group row">
<label for="email" class="col-md-4 col-form-label text-md-right">{{ __('E-Mail Address') }}</label>

<div class="col-md-6">
{{-- requiredを削除 --}}
{{-- <input id="email" type="email" class="form-control @error('email') is-invalid @enderror" name="email" value="{{ old('email') }}" required autocomplete="email" autofocus> --}}
<input id="email" type="email" class="form-control @error('email') is-invalid @enderror" name="email" value="{{ old('email') }} autocomplete="email" autofocus">

@error('email')
<span class="invalid-feedback" role="alert">
<strong>{{ $message }}</strong>
</span>
@enderror
</div>
</div>

<div class="form-group row">
<label for="password" class="col-md-4 col-form-label text-md-right">{{ __('Password') }}</label>

<div class="col-md-6">
{{-- requiredを削除 --}}
{{-- <input id="password" type="password" class="form-control @error('password') is-invalid @enderror" name="password" required autocomplete="current-password"> --}}
<input id="password" type="password" class="form-control @error('password') is-invalid @enderror" name="password" autocomplete="current-password">

@error('password')
<span class="invalid-feedback" role="alert">
<strong>{{ $message }}</strong>
</span>
@enderror
</div>
</div>

<div class="form-group row">
<div class="col-md-6 offset-md-4">
<div class="form-check">
<input class="form-check-input" type="checkbox" name="remember" id="remember" {{ old('remember') ? 'checked' : '' }}>

<label class="form-check-label" for="remember">
{{ __('Remember Me') }}
</label>
</div>
</div>
</div>

<div class="form-group row mb-0">
<div class="col-md-8 offset-md-4">
<button type="submit" class="btn btn-primary">
{{ __('Login') }}
</button>

@if (Route::has('password.request'))
<a class="btn btn-link" href="{{ route('password.request') }}">
{{ __('Forgot Your Password?') }}
</a>
@endif
</div>
</div>
</form>
</div>
</div>
</div>
</div>
</div>
@endsection



ログインバリデーションのオーバーライド

これだけだと、emailの整合性チェックのエラーを拾ってくれないので、vender下のAuthenticatesUsersのログインバリデーション部分をオーバーライドして編集する


app/Http/Controllers/Auth/LoginController.php

+    /**

+ * Validate the user login request.
+ *
+ * @param \Illuminate\Http\Request $request
+ * @return void
+ *
+ * @throws \Illuminate\Validation\ValidationException
+ */

+ protected function validateLogin(Request $request)
+ {
+ $request->validate([
+ // |emailを追加
+ //$this->username() => 'required|string',
+ $this->username() => 'required|string|email',
+ 'password' => 'required|string',
+ ]);
+ }