このページの翻訳:
- 日本語 (ja)
- English (en)
最近の更新
最近の更新
Laravelでカスタムバリデーションを作成する方法
php artisan make:provider ValidatorServiceProvider
app/Providers/ValidatorServiceProvider.php
namespace App\Providers; use Illuminate\Support\ServiceProvider; use Domain\CustomValidator; class ValidatorServiceProvider extends ServiceProvider { /** * Bootstrap the application services. * * @return void */ public function boot() { \Validator::resolver(function ($translator, $data, $rules, $messages) { return new CustomValidator($translator, $data, $rules, $messages); }); } /** * Register the application services. * * @return void */ public function register() { // } }
config/app.php
'providers' => [ ... App\Providers\ValidatorServiceProvider::class, ...
※カスタムバリデーションのメソッド名は、必ずvalidateXXXXという名前にする
app/CustomValidator.php
<?php
namespace App;
class CustomValidator extends \Illuminate\Validation\Validator
{
/**
* なまえのバリデーション
*
* @param $attribute
* @param $value
* @param $parameters
* @return bool
*/
public function validateName($attribute, $value, $parameters)
{
if (preg_match('/[^a-Z]/u', $value) !== 0) {
return false;
}
return true;
}
}
resources/lang/ja/validation.php 'name' => 'The :attribute no valid name', 'attributes' => [ ... 'family_name_name' => 'ふりがな(せい)',
$request->validate([ 'name' => 'required|Name', ]);