xzusoft / validate
验证器
1.0.1
2020-02-21 15:54 UTC
Requires
- php: >=7.1.0
- easyswoole/spl: ^1.0
Requires (Dev)
- phpunit/phpunit: ^7.4
This package is auto-updated.
Last update: 2025-03-22 02:56:34 UTC
README
默认错误信息提示
validate验证器提供了默认错误信息规则,详细如下:
private $defaultErrorMsg = [ 'activeUrl' => ':fieldName必须是可访问的网址', 'alpha' => ':fieldName只能是字母', 'between' => ':fieldName只能在 :arg0 - :arg1 之间', 'bool' => ':fieldName只能是布尔值', 'dateBefore' => ':fieldName必须在日期 :arg0 之前', 'dateAfter' => ':fieldName必须在日期 :arg0 之后', 'equal' => ':fieldName必须等于:arg0', 'float' => ':fieldName只能是浮点数', 'func' => ':fieldName自定义验证失败', 'inArray' => ':fieldName必须在 :arg0 范围内', 'integer' => ':fieldName只能是整数', 'isIp' => ':fieldName不是有效的IP地址', 'notEmpty' => ':fieldName不能为空', 'numeric' => ':fieldName只能是数字类型', 'notInArray' => ':fieldName不能在 :arg0 范围内', 'length' => ':fieldName的长度必须是:arg0', 'lengthMax' => ':fieldName长度不能超过:arg0', 'lengthMin' => ':fieldName长度不能小于:arg0', 'max' => ':fieldName的值不能大于:arg0', 'min' => ':fieldName的值不能小于:arg0', 'regex' => ':fieldName不符合指定规则', 'required' => ':fieldName必须填写', 'timestamp' => ':fieldName必须是一个有效的时间戳', 'url' => ':fieldName必须是合法的网址', ];
默认错误例子
<?php /** * Created by PhpStorm. * User: root * Date: 18-11-19 * Time: 上午10:47 */ require_once "./vendor/autoload.php"; $data = ['name' => 'blank', 'age' => 25]; // 验证数据 $validate = new \EasySwoole\Validate\Validate(); $validate->addColumn('name')->required(); // 给字段加上验证规则 $validate->addColumn('age')->required()->max(18); $bool = $validate->validate($data); // 验证结果 if ($bool) { var_dump("验证通过"); } else { var_dump($validate->getError()->__toString()); } /* * 输出结果: string(23) "age的值不能大于18" */
自定义错误信息提示
自定义错误例子
<?php /** * Created by PhpStorm. * User: root * Date: 18-11-19 * Time: 上午10:47 */ require_once "./vendor/autoload.php"; $data = ['name' => 'blank', 'age' => 25]; // 验证数据 $validate = new \EasySwoole\Validate\Validate(); $validate->addColumn('name')->required('名字不为空'); // 给字段加上验证规则 $validate->addColumn('age')->required('年龄不为空')->func(function($params, $key) { return $params instanceof \EasySwoole\Spl\SplArray && $key == 'age' && $params[$key] == 18; }, '只允许18岁的进入'); $bool = $validate->validate($data); // 验证结果 if ($bool) { var_dump("验证通过"); } else { var_dump($validate->getError()->__toString()); } /* * 输出结果: string(23) "只允许18岁的进入" */
自定义验证器类
自定义验证器类错误例子
<?php /** * Created by PhpStorm. * User: Heelie * Date: 19-12-27 * Time: 下午15:52 */ require_once "./vendor/autoload.php"; class CustomValidator implements \EasySwoole\Validate\ValidateInterface { /** * 返回当前校验规则的名字 * @return string */ public function name(): string { return 'mobile'; } /** * 检验失败返回错误信息即可 * * @param \EasySwoole\Spl\SplArray $spl * @param string $column * @param mixed ...$args * @return string|null */ public function validate(\EasySwoole\Spl\SplArray $spl, $column, ...$args): ?string { $regular = '/^((13[0-9])|(14[5,7,9])|(15[^4])|(18[0-9])|(17[0,1,3,5,6,7,8]))\\d{8}$/'; if (!preg_match($regular, $spl->get($column))) { return '手机号验证未通过'; } return null; } } // 待验证数据 $data = ['mobile' => '12312345678']; $validate = new \EasySwoole\Validate\Validate(); // 自定义错误消息示例 $validate->addColumn('mobile')->required('手机号不能为空')->callUserRule(new CustomValidator, '手机号格式不正确'); $bool = $validate->validate($data); // 验证结果 if ($bool) { var_dump("验证通过"); } else { var_dump($validate->getError()->__toString()); } /* * 输出结果:string(24) "手机号格式不正确" */