Untuk membuat dan menggunakan peraturan pengesahan tersuai di Laravel, anda boleh mengikuti langkah -langkah ini:
Tentukan peraturan tersuai:
Anda boleh menentukan peraturan pengesahan tersuai menggunakan objek peraturan. Buat kelas baru yang meluaskan Illuminate\Validation\Rules\Rule
. Sebagai contoh, jika anda ingin mengesahkan bahawa medan mengandungi perkataan tertentu, anda mungkin membuat kelas bernama ContainsWord
.
<code class="php">use Illuminate\Contracts\Validation\Rule; class ContainsWord implements Rule { private $word; public function __construct($word) { $this->word = $word; } public function passes($attribute, $value) { return stripos($value, $this->word) !== false; } public function message() { return "The :attribute must contain the word :word."; } }</code>
Gunakan peraturan tersuai:
Untuk menggunakan peraturan tersuai dalam pengawal atau permintaan borang anda, anda boleh memberi instantiasi peraturan dan lulus kepada kaedah validate
.
<code class="php">use App\Rules\ContainsWord; $request->validate([ 'title' => ['required', new ContainsWord('Laravel')], ]);</code>
Menggunakan Peraturan Kustom dalam Permintaan Borang:
Jika anda menggunakan permintaan borang, anda boleh memasukkan peraturan dalam kaedah rules
.
<code class="php">use App\Rules\ContainsWord; use Illuminate\Foundation\Http\FormRequest; class StorePostRequest extends FormRequest { public function rules() { return [ 'title' => ['required', new ContainsWord('Laravel')], ]; } }</code>
Menggunakan peraturan pengesahan tersuai di Laravel menawarkan beberapa faedah:
Kebolehgunaan semula:
Ekspresi:
Kekhususan:
Konsistensi:
Kesesuaian:
Untuk memperluaskan sistem pengesahan Laravel dengan peraturan tersuai anda sendiri, anda boleh mengikuti pendekatan ini:
Menggunakan objek peraturan:
Illuminate\Validation\Rules\Rule
. Ini adalah kaedah pilihan untuk peraturan kompleks.Menggunakan penutupan:
Untuk peraturan mudah, anda boleh menentukan penutupan dalam peraturan pengesahan anda.
<code class="php">$request->validate([ 'title' => [ 'required', function ($attribute, $value, $fail) { if (stripos($value, 'Laravel') === false) { $fail('The '.$attribute.' must contain the word "Laravel".'); } }, ], ]);</code>
Memperluas Validator:
Anda boleh melanjutkan fasad Validator
untuk menambah peraturan baru yang boleh digunakan sepanjang aplikasi anda.
<code class="php">use Illuminate\Support\Facades\Validator; Validator::extend('contains_word', function ($attribute, $value, $parameters, $validator) { $word = $parameters[0]; return stripos($value, $word) !== false; }); Validator::replacer('contains_word', function ($message, $attribute, $rule, $parameters) { return str_replace(':word', $parameters[0], $message); });</code>
Anda kemudian boleh menggunakan peraturan tersuai dalam pengesahan anda.
<code class="php">$request->validate([ 'title' => 'required|contains_word:Laravel', ]);</code>
Terdapat beberapa sumber di mana anda dapat mencari contoh dan tutorial untuk melaksanakan peraturan pengesahan tersuai di Laravel:
Dokumentasi Rasmi Laravel:
Laracasts:
Berita Laravel:
Github:
Stack Overflow:
Blog Komuniti Laravel:
Dengan memanfaatkan sumber -sumber ini, anda boleh mendapatkan pemahaman yang lebih mendalam tentang cara melaksanakan peraturan pengesahan tersuai di Laravel dengan berkesan.
Atas ialah kandungan terperinci Bagaimanakah saya boleh membuat dan menggunakan peraturan pengesahan tersuai di Laravel?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!