在开发一个用户注册系统时,我面临着一个复杂的数据验证问题。用户可能会提交各种格式的数据,包括电子邮件、密码、文件上传等,这些数据需要通过一系列规则来验证,以确保其有效性和安全性。然而,编写这些验证逻辑不仅耗时,而且容易出错。经过一番研究,我发现了 rakit/validation 这个库,它大大简化了我的验证工作。
Rakit/Validation 是一个独立的 php 验证库,灵感来源于 laravel 的验证系统。它提供了与 Laravel 类似的 API,使得在非 Laravel 项目中使用这些验证功能变得非常方便。使用 composer 可以轻松安装这个库:
composer require rakit/validation
以下是使用 Rakit/Validation 进行数据验证的一些示例:
基本使用
你可以使用 make 方法创建一个验证对象,然后调用 validate 方法进行验证,或者直接使用 validate 方法:
<?php require('vendor/autoload.php'); use RakitValidationValidator; $validator = new Validator; // 使用 `make` 方法 $validation = $validator->make($_POST + $_FILES, [ 'name' => 'required', 'email' => 'required|email', 'password' => 'required|min:6', 'confirm_password' => 'required|same:password', 'avatar' => 'required|uploaded_file:0,500K,png,jpeg', 'skills' => 'Array', 'skills.*.id' => 'required|numeric', 'skills.*.percentage' => 'required|numeric' ]); $validation->validate(); if ($validation->fails()) { // 处理错误 $errors = $validation->errors(); echo "<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">"; print_r($errors->firstOfAll()); echo "
“; exit; } else { // 验证通过 echo “Success!”; } // 或者直接使用 `validate` 方法 $validation = $validator->validate($_POST + $_FILES, [ ‘name’ => ‘required’, ’email’ => ‘required|email’, ‘password’ => ‘required|min:6’, ‘confirm_password’ => ‘required|same:password’, ‘avatar’ => ‘required|uploaded_file:0,500K,png,jpeg’, ‘skills’ => ‘array’, ‘skills.*.id’ => ‘required|numeric’, ‘skills.*.percentage’ => ‘required|numeric’ ]); if ($validation->fails()) { // 处理错误 $errors = $validation->errors(); echo “
"; print_r($errors->firstOfAll()); echo "
“; exit; } else { // 验证通过 echo “Success!”; }
自定义属性别名和错误消息
Rakit/Validation 允许你自定义属性别名和错误消息。例如,你可以使用 setAlias 或 setAliases 方法来设置属性别名:
立即学习“PHP免费学习笔记(深入)”;
$validator = new Validator; $validation = $validator->make([ 'province_id' => $_POST['province_id'], 'district_id' => $_POST['district_id'] ], [ 'province_id' => 'required|numeric', 'district_id' => 'required|numeric' ]); $validation->setAlias('province_id', 'Province'); $validation->setAlias('district_id', 'District'); // 或者 $validation->setAliases([ 'province_id' => 'Province', 'district_id' => 'District' ]); $validation->validate();
你也可以自定义错误消息:
$validator = new Validator([ 'required' => ':attribute harus diisi', 'email' => ':email tidak valid', ]); // 或者使用 `setMessages` 方法 $validator->setMessages([ 'required' => ':attribute harus diisi', 'email' => ':email tidak valid', ]);
处理错误消息
Rakit/Validation 提供了一些方法来处理和获取错误消息:
$validation = $validator->validate($inputs, $rules); $errors = $validation->errors(); $messages = $errors->all(); $messages = $errors->firstOfAll(); $message = $errors->first('email'); $messages = $errors->toArray(); $count = $errors->count(); $hasError = $errors->has('email');
获取验证数据
你可以使用以下方法获取验证后的数据:
$validatedData = $validation->getValidatedData(); $validData = $validation->getValidData(); $invalidData = $validation->getInvalidData();
自定义验证规则
Rakit/Validation 允许你创建自定义验证规则。例如,你可以创建一个 UniqueRule 类来检查数据库中的唯一性:
class UniqueRule extends Rule { protected $message = ":attribute :value has been used"; protected $fillableParams = ['table', 'column', 'except']; protected $pdo; public function __construct(PDO $pdo) { $this->pdo = $pdo; } public function check($value): bool { $this->requireParameters(['table', 'column']); $column = $this->parameter('column'); $table = $this->parameter('table'); $except = $this->parameter('except'); if ($except AND $except == $value) { return true; } $stmt = $this->pdo->prepare("select count(*) as count from `{$table}` where `{$column}` = :value"); $stmt->bindParam(':value', $value); $stmt->execute(); $data = $stmt->fetch(PDO::FETCH_ASSOC); return intval($data['count']) === 0; } } $validator = new Validator; $validator->addValidator('unique', new UniqueRule($pdo)); $validation = $validator->validate($_POST, [ 'email' => 'email|unique:users,email,exception@mail.com' ]);
使用 Rakit/Validation 库,我能够轻松地在我的项目中实现复杂的数据验证。它不仅简化了我的验证逻辑,还提供了高度的灵活性和可定制性,使得我的用户注册系统更加健壮和安全。如果你也在寻找一个高效的 PHP 数据验证解决方案,那么 Rakit/Validation 绝对值得一试。