在 Laravel 中,您可以使用自定义验证规则来设置所有字段的默认 bail
行为。bail
规则确保在遇到第一个验证失败时,不会继续验证该字段的其他规则。这在某些情况下可以提高性能,并减少无效的反馈。
要为所有验证器类的字段默认使用 bail
,可以通过以下步骤来实现:
您可以创建一个自定义的 Validator 类,其中注册所有规则的默认设置。使用一个 ServiceProvider
来将其注册。
// 在 app/Providers 文件夹中创建一个新的 ServiceProvider php artisan make:provider CustomValidationServiceProvider
在 CustomValidationServiceProvider
中,您可以以 boot
方法注册全局的验证扩展,从而将 bail
应用于所有字段。
namespace App\Providers; use Illuminate\Support\ServiceProvider; use Illuminate\Support\Facades\Validator; class CustomValidationServiceProvider extends ServiceProvider { public function boot() { // 注册全局验证规则 Validator::macro('bailAll', function ($attribute, $value, $parameters, $validator) { return Validator::make([$attribute => $value], [ '*' => 'bail', ])->validate(); }); } public function register() { // } }
这段代码创建一个名为 bailAll
的宏,用于在验证时应用 bail
规则。
打开 app/Providers/AppServiceProvider.php
,并在 register
方法中注册您的 CustomValidationServiceProvider
:
public function register() { $this->app->register(CustomValidationServiceProvider::class); }
在您需要使用验证器的地方,可以通过调用自定义验证宏来实现全局的 bail
规则:
$data = $request->all(); $validator = Validator::make($data, [ 'name' => 'required|string', 'email' => 'required|email', 'password' => 'required|string|min:8', ]); // 调用 bailAll 以支持所有字段 bail $validator->after(function ($validator) { foreach ($data as $attribute => $value) { $this->bailAll($attribute, $value, [], $validator); } }); if ($validator->fails()) { return response()->json($validator->errors(), 400); } // 验证成功
请确保您在 config/app.php
中的 providers
数组中注册了新的 Service Provider:
'providers' => [ ... App\Providers\CustomValidationServiceProvider::class, ],
虽然 Laravel 没有提供直接的方式来设置所有验证器的字段默认使用 bail
,可以通过创建自定义验证规则的方法来实现此目的。以上步骤为您提供了一种实现方式,您可以根据自己的应用需求进行调整。
标签: 来源:
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。