本文實例講述了laravel框架使用FormRequest進行表單驗證,驗證異常返回JSON操作.分享給大家供大家參考,具體如下:
通常在項目中,我們會對大量的前端提交過來的表單進行驗證,如果不通過,則返回錯誤信息。
前端為了更好的體驗,都使用ajax進行表單提交,雖然 validate()
方法能夠根據(jù)前端的不同請求方式,返回不同的結(jié)果。
但是返回的json格式并不是我們想要的,這個時候,我們就需要自定義返回錯誤結(jié)果。
先創(chuàng)建一個表單請求類:
php artisan make:request TestRequest
然后在 rules()
和 messages()
方法里填寫自已的驗證規(guī)則和消息
?php
namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Contracts\Validation\Validator;
use Illuminate\Http\Exceptions\HttpResponseException;
class TestRequest extends FormRequest
{
/**
* 控制訪問權(quán)限
*/
public function authorize()
{
//注意,默認是false,改成true
return true;
}
/**
* 驗證規(guī)則
*/
public function rules()
{
return [
'name' => 'required',
'pwd' => 'required',
];
}
/**
* 驗證消息
*/
public function messages()
{
return [
'name.required' => '姓名必填',
'pwd.required' => '密碼必填',
];
}
}
注意,父類 FormRequest中的 failedValidation()
方法用來處理驗證失敗,我們重寫父類方法,來實現(xiàn)自已的返回。
public function failedValidation(Validator $validator)
{
throw (new HttpResponseException(response()->json([
'status_code' => 500,
'message' => '請求錯誤',
'data' => $validator->errors()->first(),
], 200)));
}
注意 failedValidation()
方法的 $validator 參數(shù)是 Illuminate\Contracts\Validation\Validator 對象,不是 Illuminate\Validation\Validator,不要搞錯了。
更多關于Laravel相關內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設計有所幫助。
您可能感興趣的文章:- 如何重寫Laravel異常處理類詳解
- Laravel如何實現(xiàn)適合Api的異常處理響應格式
- Laravel 修改驗證異常的響應格式實例代碼詳解
- Laravel 解決composer相關操作提示php相關異常的問題
- Laravel 5.5 異常處理 & 錯誤日志的解決
- 解決laravel 表單提交-POST 異常的問題
- laravel框架 api自定義全局異常處理方法
- Laravel核心解讀之異常處理的實踐過程
- 淺談Laravel中使用Slack進行異常通知