AJAX ОШИБКА ВАЛИДАЦИИ не отображается на странице входа в систему, но отображается в сети консоли режима разработчика в laravel - PullRequest
0 голосов
/ 22 апреля 2020

проблема заключается в том, что когда я отправляю форму, логин становится успешным, когда я делаю с правильным созданием. Но когда я логинюсь с неверной информацией, сообщение проверки не отображает ошибку.

<script type="text/javascript">

    // Set default CSRF header
    $.ajaxSetup({
        headers: {
            'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
        }
    });

    // Intercept login form
    $('#login-form').submit(function(e){

        // Prevent normal form submission, we well do in JS instead
        e.preventDefault();

        // Get form data
        var data = {
                email: $('[name=email]').val(),
                password: $('[name=password]').val(),
                remember: $('[name=remember]').val(),
            };

        // Send the request
        $.post($('this').attr('action'), data, function(response) {
            if (response.success) {
                // If login success, redirect
                window.location.replace(response.redirect);
            }
        });
    });

Контроллер входа из и здесь метод входа и регистрации работает очень хорошо, но единственной проблемой является сообщение проверки не отображается.

protected function sendLoginResponse(Request $request)
    {
        $request->session()->regenerate();

        $this->clearLoginAttempts($request);

        if($request->ajax()){
            // If request from AJAX
            return [
                'success' => true,
                'redirect' => $this->redirectPath() ?: route('home'),
            ];
        } else {
            // Normal POST do redirect
            return $this->authenticated($request, $this->guard()->user())
                    ?: redirect()->intended($this->redirectPath());
        }
    }

html форма, в которой идентификатор пытается отображать или отображать ошибки при входе в систему

<form id="login-form" class="form-horizontal" method="POST" action="{{ route('login') }}">
                        {{ csrf_field() }}

                        <div class="form-group{{ $errors->has('email') ? ' has-error' : '' }}">
                            <label for="email" class="col-md-4 control-label">E-Mail Address</label>

                            <div class="col-md-6">
                                <input id="email" type="email" class="form-control" name="email" value="{{ old('email') }}" required autofocus>

                                @if ($errors->has('email'))
                                    <span class="help-block">
                                        <strong>{{ $errors->first('email') }}</strong>
                                    </span>
                                @endif
                            </div>
                        </div>

                        <div class="form-group{{ $errors->has('password') ? ' has-error' : '' }}">
                            <label for="password" class="col-md-4 control-label">Password</label>

                            <div class="col-md-6">
                                <input id="password" type="password" class="form-control" name="password" required>

                                @if ($errors->has('password'))
                                    <span class="help-block">
                                        <strong>{{ $errors->first('password') }}</strong>
                                    </span>
                                @endif
                            </div>
                        </div>

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

                        <div class="form-group">
                            <div class="col-md-8 col-md-offset-4">
                                <button type="submit" class="btn btn-primary">
                                    Login
                                </button>

                                <a class="btn btn-link" href="{{ route('password.request') }}">
                                    Forgot Your Password?
                                </a>
                            </div>
                        </div>
                    </form>

1 Ответ

0 голосов
/ 22 апреля 2020

Вы получаете ошибку проверки в Ajax формате, так как ваш запрос Ajax. Вы можете обработать ошибки в Javascript напрямую:

Я не проверял его, но он должен дать вам несколько указаний.

        $.post($('this').attr('action'), data, function(response) {
            if (response.success) {
                // If login success, redirect
                window.location.replace(response.redirect);
            } else {
                if (response.errors.email)
                    $('#email-error').text(response.errors.email[0]);

                if (response.errors.password)
                    $('#password-error').text(response.errors.password[0]);
            }
        });

И изменить ваш шаблон лезвия следующим образом:

<form id="login-form" class="form-horizontal" method="POST" action="{{ route('login') }}">
    {{ csrf_field() }}

    <div class="form-group">
        <label for="email" class="col-md-4 control-label">E-Mail Address</label>

        <div class="col-md-6">
            <input id="email" type="email" class="form-control" name="email" value="{{ old('email') }}" required
                   autofocus>
            <span class="help-block" id="email-error"></span>
        </div>
    </div>

    <div class="form-group">
        <label for="password" class="col-md-4 control-label">Password</label>

        <div class="col-md-6">
            <input id="password" type="password" class="form-control" name="password" required>
            <span class="help-block" id="password-error"></span>
        </div>
    </div>

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

    <div class="form-group">
        <div class="col-md-8 col-md-offset-4">
            <button type="submit" class="btn btn-primary">
                Login
            </button>

            <a class="btn btn-link" href="{{ route('password.request') }}">
                Forgot Your Password?
            </a>
        </div>
    </div>
</form>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...