Перенаправление назад с вводом, не работающим в laravel 5.5 - PullRequest
0 голосов
/ 08 мая 2018

Я использовал перенаправление назад с вводом много раз ранее. Но в этом проекте я не могу этого сделать. Это мой контроллер метод, который обрабатывает запрос формы:

public function verifyMobileCode( Request $request)
{
        $userId = Auth::user()->id;
        if( Auth::user()->verification_code == $request['verification_code'])
        {
            User::where('id', $userId)->update(['verified'=>1]);
            return redirect('/')->with('success', 'Account verified.');
        }
        else
        {
            return redirect()->back()->withErrors('verification_code' ,'unv' )->withInput($request->all());
        }
}

Это мой клинок:

@extends('layouts.index')

@section('content')

<div class="container" style='padding-top: 150px;'>

    <?php var_dump($errors) ; ?>
    <div class="row">
        <div class="col-md-8 col-md-offset-2">
            <div class="panel panel-default">
                <div class="panel-heading">Verify your mobile</div>

                <div class="panel-body">
                    <form class="form-horizontal" method="POST" action="{{ route('verifyMobileCode') }}">
                        {{ csrf_field() }}

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

                            <div class="col-md-6">
                                <input id="verification_code" type="text" class="form-control" name="verification_code" value="{!! old('verification_code') !!}" required autofocus maxlength="6" pattern="\d{6}">

                                @if ($errors->has('verification_code'))
                                    <span class="help-block">
                                        <strong>Please enter 6 digit number sent to your mobile.</strong>
                                    </span>
                                @endif
                            </div>
                        </div>
                        <div class="form-group">
                            <div class="col-md-6 col-md-offset-4">
                                <button type="submit" class="btn btn-primary">
                                    Register
                                </button>
                            </div>
                        </div>
                    </form>
                </div>
            </div>
        </div>
    </div>
</div>
@endsection

Мой Kernel.php выглядит следующим образом:

<?php

namespace App\Http;

use Illuminate\Foundation\Http\Kernel as HttpKernel;

class Kernel extends HttpKernel
{
    /**
     * The application's global HTTP middleware stack.
     *
     * These middleware are run during every request to your application.
     *
     * @var array
     */
    protected $middleware = [
        \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
        \Illuminate\Session\Middleware\StartSession::class,
        \App\Http\Middleware\LanguageSwitcher::class,
        \Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
        \App\Http\Middleware\TrimStrings::class,
        \Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
        \App\Http\Middleware\TrustProxies::class,
    ];

    /**
     * The application's route middleware groups.
     *
     * @var array
     */
    protected $middlewareGroups = [
        'web' => [
            \App\Http\Middleware\EncryptCookies::class,
            \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
            \Illuminate\Session\Middleware\StartSession::class,
            // \Illuminate\Session\Middleware\AuthenticateSession::class,
            \Illuminate\View\Middleware\ShareErrorsFromSession::class,
            \App\Http\Middleware\VerifyCsrfToken::class,
            \Illuminate\Routing\Middleware\SubstituteBindings::class,
        ],

        'api' => [
            'throttle:60,1',
            'bindings',
        ],
    ];

    /**
     * The application's route middleware.
     *
     * These middleware may be assigned to groups or used individually.
     *
     * @var array
     */
    protected $routeMiddleware = [
        'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
        'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
        'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
        'can' => \Illuminate\Auth\Middleware\Authorize::class,
        'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
        'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
        'is-admin' => \App\Http\Middleware\IsAdminMiddleware::class,
    ];
}

Я не нахожу ошибки или что-то не так. Есть что-нибудь, что ты видишь? Есть ли техника для отладки этого поведения? Заранее спасибо.

Ответы [ 5 ]

0 голосов
/ 15 мая 2018

Ваш контроллер должен выглядеть следующим образом:

public function verifyMobileCode( Request $request)
{
    $userId = Auth::user()->id;
    if( Auth::user()->verification_code == $request['verification_code'])
    {
        User::where('id', $userId)->update(['verified'=>1]);
        return redirect('/')->with('success', 'Account verified.');
    }
    else
    {
        return redirect()->back()->withErrors('message' ,'Please some errors encountered.' );
    }
}

И изменить это

<div class="form-group{{ $errors->has('verification_code') ? ' has-error' : '' }}">

Для этого:

<div class="form-group>
@include('errors');

Также создайте файл с именем errors.blade.phpв ресурсах / представлениях и поместите следующий код:

@if ($errors->any())
<div class="card"> //incase bootstrap 4
    <div class="error card-body alert alert-danger">
        <ul>
            @foreach ($errors->all() as $error)
                <li>{{ $error }}</li>
            @endforeach
        </ul>
    </div>
</div>
@endif

Надеюсь, это работает для вас.Но вам не нужно отображать старые входные данные, так как код будет неправильным или что-то случилось.Так что не нужно

0 голосов
/ 14 мая 2018
return redirect()->back()->withInput()->withErrors('verification_code' ,'unv' );
0 голосов
/ 11 мая 2018

Замените ->withInput($request->all()); на ->withInput();

, если вы не хотите использовать какой-либо из входных данных, используйте

->withInput( $request->except('input_name') );

0 голосов
/ 11 мая 2018

Чтобы отладить это, не прибегая к Xdebug, можно быстро добавить временный код отладки в начало файла blade-сервера:

@php
    dd($errors->toArray(), $errors->has('verification_code'));
@endphp

Что даст вам следующий вывод:

array:1 [
  0 => array:1 [
    0 => "verification_code"
  ]
]
false

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

Быстрое решение состоит в том, чтобы изменить используемый контроллер:

->withErrors(['verification_code' => 'unv'])

withErrors ожидает, что MessageBag или массив, но приведёт строку к массиву, что не приведет к правильной паре ключ / значение.

Вывод отладки теперь будет отображать:

array:1 [
  "verification_code" => array:1 [
    0 => "unv"
  ]
]
true

Теперь можно удалить код отладки, и ошибка должна отображаться так, как вы ожидаете.

Надлежащим способом Laravel, вероятно, является использование $ request-> validate () или FormRequest для сложных форм. Для получения дополнительной информации см. Документацию проверки Laravel (https://laravel.com/docs/5.5/validation).

0 голосов
/ 08 мая 2018

Мой подход будет использовать FormRequest .

php artisan make:request VerifyCodeRequest

И тело запроса:

<?php

namespace App\Http\Requests;

use Illuminate\Foundation\Http\FormRequest;

class VerifyCodeRequest extends FormRequest
{

    /**
     * Determine if the user is authorized to make this request.
     *
     * @return bool
     */
    public function authorize()
    {
        return true;
    }


    /**
     * Get the validation rules that apply to the request.
     *
     * @return array
     */
    public function rules()
    {
        return [
            'verification_code' => 'required|in:'.$this->user()->verification_code, // since user is already logged in we check if verification_code matches using `in` rule
        ];
    }


    public function messages()
    {
        return [
            'in' => 'Your custom error message if we failed',
        ];
    }
}

Теперь вы меняете подпись verifyMobileCode(...) на следующую verifyMobileCode(App\Http\Requests\VerifyCodeRequest $request).

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

public function verifyMobileCode(App\Http\Requests\VerifyCodeRequest $request)
{
    $request->user()->verify();
    return redirect('/')->with('success', 'Account verified.');
}

Внутри модели пользователя добавить verify() функция

public function verify() 
{
    $this->update(['verified' => true]);
}

Если ваш вышеприведенный подход не работает, есть проблема с вашим app/Http/Kernel.php. Вы использовали

\Illuminate\Session\Middleware\StartSession::class,

дважды. Вы должны удалить один. Вероятно, первый.

Посмотреть на складе Laravel's kernel.php .

...