FuelPHP 验证
验证 是 Web 应用程序中最频繁和最重复的任务之一。用户在表单中输入所需的数据并提交。然后,Web 应用程序需要在处理数据之前验证数据。例如,用户输入员工数据,post_action 需要验证,然后才能将其保存到数据库中。 FuelPHP 为此提供了一个非常简单的类 Validation。
在 FuelPHP 中,验证的概念非常简单,它通过 Validation 类提供各种方法来正确验证表单。以下是验证的工作流程,
步骤 1-使用 forge 方法创建新的验证对象。
$val = Validation::forge();
步骤 2-添加需要使用 add 方法验证的字段。
$val->add('name', 'Employee name');
步骤 3-使用 add_rule 为添加的字段设置验证规则。
$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);
步骤 4-调用 run 方法来验证数据。
// run validation on just post if ($val->run()) { // success } else { // falier }
步骤 5-使用验证和错误分别获取有效和无效字段。
$vars = $val->validated(); $vars = $val->error();
规则
FuelPHP 包含许多要验证的规则,还提供了创建新规则的选项。 Validation类支持的规则如下,
- required-要输入的值
- required_with-将另一个字段设置为伴随字段。如果设置了字段,则还需要设置伴随字段
- match_value-设置要与字段值匹配的值
- match_pattern-将要匹配的值设置为与字段值匹配的正则表达式
- match_field-将另一个字段的值设置为与该字段值匹配的值
- match_collection-将要匹配的值设置为具有字段值的集合
- min_length-设置字段值的最小长度
- max_length-设置字段值的最大长度
- exact_length-设置字段值的确切长度
- valid_date-将字段的值设置为有效日期
- valid_email-将字段的值设置为有效的电子邮件
- valid_emails-将字段的值设置为有效的电子邮件,以逗号分隔
- valid_url-将字段的值设置为有效的 URL
- valid_ip-将字段的值设置为有效的 IP
- numeric_min-设置字段值的最小值
- numeric_max-设置字段值的最大值
- numeric_between-设置字段值的最小值和最大值
- valid_string-类似于正则表达式,但更简单
$val->add('username', 'User name')->add_rule('valid_string', array('alpha, dots');
这里,alpha 指的是字母字符,点指的是 (.)。有效字符串仅是包含字母字符和 (.) 的字符串。其他选项是大写、小写、特殊、数字、空格等。
工作示例
我们可以更新添加员工功能以包含验证。只需更新员工控制器的 post_add 方法,如下所示。
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'); } }
在这里,我们指定了 姓名和年龄作为必填字段。 age 需要在 20 到 30 之间。如果两个规则都有效,则员工数据将被保存并重定向到员工列表页面。否则,员工数据将被拒绝并重定向到添加员工页面。
下一章:FuelPHP 高级表单编程
FuelPHP 通过 Fieldset 和 Fieldset_Field 类提供高级表单编程。 Fieldset 提供了一种面向对象的方式来创建表单。它完全支持模型。它还内置了对客户端和服务器端验证 ...