FormRequest failed validation returns 500 error in

2020-07-10 09:14发布

After updating from L5.1 to L5.2, I no longer receive a JSON object as response on a failed FormRequest (i.e. on an AJAX post request).

Usually I would receive a 422 response like:

[
    email: 'E-mail is invalid',
    firstname: 'Firstname must be at least 2 characters'
]

But now I receive a 500 error page:

500 response page

I have ensured that my AJAX calls have application/json as Accept header.

Update

And no, I am not manually catching this exception. I am using the default FormRequest that Laravel provides. As they state in documentation: When using the validate method during an AJAX request, Laravel will not generate a redirect response. Instead, Laravel generates a JSON response containing all of the validation errors. This JSON response will be sent with a 422 HTTP status code.

Like so: php artisan make:request StoreBlogPostRequest (https://laravel.com/docs/5.1/validation#form-request-validation)

3条回答
冷血范
2楼-- · 2020-07-10 09:42

@Mattias!

I've recently had the same issue and I wasted more than 2 hours trying to understand what actually causes this problem. Disabling debugging in .env file causes form validation to display 500 since the FormValidator throws ValidationException (and it is unhandled). The solution for this issue was: Open app\Exceptions\Handler.php

private function handleExceptions($e)
    {
       // Add anywhere in this method the following code
       // It does what the FormValidator does.

        if($e instanceof ValidationException) {

            return redirect()->back()->withErrors($e->validator->getMessageBag()->toArray());
        }

        return response()->view('errors.500', [], 500);
    }
查看更多
虎瘦雄心在
3楼-- · 2020-07-10 10:01

To reiterate what the others have said, you more than likely have a modified app/Exceptions/Handler.php in your project where you have some code that is preventing you from seeing the result you'd hoped for.

All exceptions are handled by the App\Exceptions\Handler class. This class contains two methods: report and render.

Double check app/Exceptions/Handler.php and the documentation regarding exception handlers at https://laravel.com/docs/5.2/errors#the-exception-handler to make sure you're handling exceptions as you'd intended.

查看更多
太酷不给撩
4楼-- · 2020-07-10 10:06

I came against the same problem using Laravel 5.7.

If you read the /storage/logs/laravel-yyyy-mm-dd.log file you will find the error. In my case the error occurred because I forgot a step when linking the StoreLocation request in my Controller:

The error in the log:

[2018-12-13 09:48:09] local.ERROR: Class App\Requests\StoreLocation does not exist

It is perfectly clear that I started writing code without having my coffee first!

The solution:

use App\Http\Requests\StoreLocation;

I added the correct path StoreLocation.php class. After fixing that, everything went back to normal and started sending the 422 response.

PS1: To get the logs, ensure debug mode is on: add APP_DEBUG=true to .env file

PS2: The log file stores the latest entries at the bottom

查看更多
登录 后发表回答