在开发一个用户注册系统时,我面临着一个复杂的数据验证问题。用户可能会提交各种格式的数据,包括电子邮件、密码、文件上传等,这些数据需要通过一系列规则来验证,以确保其有效性和安全性。然而,编写这些验证逻辑不仅耗时,而且容易出错。经过一番研究,我发现了 rakit/validation 这个库,它大大简化了我的验证工作。
Rakit/Validation 是一个独立的 PHP 验证库,灵感来源于 Laravel 的验证系统。它提供了与 Laravel 类似的 API,使得在非 Laravel 项目中使用这些验证功能变得非常方便。使用 Composer 可以轻松安装这个库:
composer require rakit/validation
以下是使用 Rakit/Validation 进行数据验证的一些示例:
基本使用
你可以使用 make 方法创建一个验证对象,然后调用 validate 方法进行验证,或者直接使用 validate 方法:
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 "";
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 绝对值得一试。











