FuelPHP - Validasi
Validationadalah salah satu tugas yang sering dan paling sering dilakukan dalam aplikasi web. Pengguna memasukkan data yang diperlukan dalam formulir dan mengirimkannya. Kemudian, aplikasi web perlu melakukan validasi data sebelum memproses data tersebut. Misalnya, pengguna memasukkan data karyawan dan post_action perlu memvalidasi sebelum menyimpannya ke dalam database. FuelPHP menyediakan kelas yang sangat sederhana, Validasi untuk tujuan ini.
Di FuelPHP, konsep validasi sangat sederhana dan menyediakan berbagai metode melalui kelas Validasi untuk memvalidasi formulir dengan benar. Berikut adalah alur kerja validasi,
Step 1 - Buat objek Validasi baru menggunakan forge metode.
$val = Validation::forge();
Step 2 - Tambahkan bidang yang perlu divalidasi menggunakan metode tambah.
$val->add('name', 'Employee name');
Step 3 - Tetapkan aturan validasi untuk bidang yang ditambahkan menggunakan add_rule metode.
$val->add('name', 'Employee name')->add_rule('required');
$val->add('age', 'Employee age')->add_rule('required')
->add_rule('numeric_min', 20)
->add_rule('numeric_max', 30);
Step 4 - Panggil metode run untuk memvalidasi data.
// run validation on just post
if ($val->run()) {
// success
} else {
// falier
}
Step 5 - Gunakan tervalidasi dan kesalahan untuk mendapatkan masing-masing bidang yang valid dan tidak valid.
$vars = $val->validated();
$vars = $val->error();
Aturan
FuelPHP berisi banyak aturan untuk divalidasi, dan juga menyediakan opsi untuk membuat aturan baru. Aturan yang didukung oleh kelas Validasi adalah sebagai berikut,
required - Nilai yang akan dimasukkan
required_with- Tetapkan bidang lain sebagai bidang pendamping. Jika bidang disetel, bidang pengiring juga perlu disetel
match_value - Atur nilai yang akan dicocokkan dengan nilai bidang
match_pattern - Tetapkan nilai yang akan dicocokkan sebagai ekspresi reguler dengan nilai bidang
match_field - Tetapkan nilai bidang lain sebagai nilai yang akan dicocokkan dengan nilai bidang
match_collection - Atur nilai yang akan dicocokkan sebagai koleksi dengan nilai bidang
min_length - Tetapkan panjang minimum nilai bidang
max_length - Tetapkan panjang maksimum nilai bidang
exact_length - Tetapkan panjang yang tepat dari nilai bidang
valid_date - Tetapkan nilai bidang ke tanggal yang valid
valid_email - Setel nilai bidang ke email yang valid
valid_emails - Setel nilai bidang ke email yang valid, dipisahkan dengan koma
valid_url - Setel nilai bidang ke URL yang valid
valid_ip - Setel nilai bidang ke IP yang valid
numeric_min - Tetapkan nilai minimum dari nilai bidang
numeric_max - Tetapkan nilai maksimum dari nilai bidang
numeric_between - Tetapkan nilai minimum dan maksimum dari nilai bidang
valid_string - Mirip dengan regex tetapi lebih sederhana
$val->add('username', 'User name')->add_rule('valid_string', array('alpha, dots');
Di sini, alfa merujuk pada karakter alfabet dan titik merujuk ke (.). String yang valid hanyalah string yang berisi karakter alfabet dan (.). Opsi lainnya adalah huruf besar, huruf kecil, spesial, numerik, spasi, dll.
Contoh Kerja
Kami dapat memperbarui fitur tambah karyawan untuk memasukkan validasi. Perbarui sajapost_add metode pengontrol karyawan sebagai berikut.
public function post_add() {
$val = Validation::forge();
$val->add('name', 'Employee name')->add_rule('required');
$val->add('age', 'Employee age')->add_rule('required')
->add_rule('numeric_min', 20)
->add_rule('numeric_max', 30);
if ($val->run()) {
$name = Input::post('name');
$age = Input::post('age');
$model = new model_employee();
$model->name = $name;
$model->age = $age;
$model->save();
Response::redirect('employee/list');
} else {
Response::redirect('employee/add');
}
}
Di sini, kami telah menentukan namedan usia sebagai bidang wajib. Ituageharus antara 20 dan 30. Jika kedua aturan tersebut valid, maka data karyawan akan disimpan dan diarahkan ke halaman daftar karyawan. Jika tidak, data karyawan akan ditolak dan diarahkan ke halaman menambahkan karyawan.