Laravel 5自定义验证重定向

问题描述 投票:8回答:4

我有一个网站,包括2个不同的登录表单,2个位置,一个在导航栏上,另一个是登录页面,将在系统捕获未登记的访问者时使用。

我可以问一下我在LoginRequest.php中做错了什么,如果登录过程中出现任何类型的错误,我会设置一个重定向到自定义登录页面的条件?我的代码如下:

<?php namespace App\Http\Requests;

use App\Http\Requests\Request;

class LoginRequest extends Request {

    /**
     * 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 [
        'login_email'               =>  'required',
        'login_password'            =>  'required'
        ];
    }


    public function messages()
    {
        return [
            'login_email.required'          =>  'Email cannot be blank',
            'login_password.required'       =>  'Password cannot be blank'
        ];
    }

    public function redirect()
    {
        return redirect()->route('login');
    }
}

如果登录页面有任何错误但代码似乎没有重定向,则代码假定重定向从导航栏登录的用户。

谢谢。

php laravel laravel-5 laravel-routing laravel-validation
4个回答
7
投票

找到了解决方案。我需要做的就是覆盖初始响应

FormRequest.php

像这样,它就像一个魅力。

public function response(array $errors)
{
    // Optionally, send a custom response on authorize failure 
    // (default is to just redirect to initial page with errors)
    // 
    // Can return a response, a view, a redirect, or whatever else

    if ($this->ajax() || $this->wantsJson())
    {
        return new JsonResponse($errors, 422);
    }
    return $this->redirector->to('login')
         ->withInput($this->except($this->dontFlash))
         ->withErrors($errors, $this->errorBag);
}

3
投票

如果要重定向到特定网址,请使用protected $redirect

class LoginRequest extends Request
{
    protected $redirect = "/login#form1";

    // ...
}

或者如果要重定向到命名路由,请使用$redirectRoute

class LoginRequest extends Request
{
    protected $redirectRoute = "session.login";

    // ...
}

1
投票

如果你在validate()上使用Controller方法

$this->validate($request, $rules);

然后你可以覆盖buildFailedValidationResponse来自你扩展的基础ValidatesRequests上的Controller特征。

这条线上的东西:

protected function buildFailedValidationResponse(Request $request, array $errors)
{
    if ($request->expectsJson()) {
        return new JsonResponse($errors, 422);
    }

    return redirect()->route('login');
}

1
投票

如果您不想对请求使用validate方法,则可以使用Validator外观手动创建验证程序实例。 Facade上的make方法生成一个新的验证器实例:请参阅Laravel Validation

 public function store(Request $request)
   {
    $validator = Validator::make($request->all(), [
        'title' => 'required|unique:posts|max:255',
        'body' => 'required',
    ]);

    if ($validator->fails()) {
        return redirect('post/create')
                    ->withErrors($validator)
                    ->withInput();
    }

    // Store the blog post...
    }
© www.soinside.com 2019 - 2024. All rights reserved.