qianlong/validate

An efficient swoole framework

dev-main 2021-03-19 16:51 UTC

This package is auto-updated.

Last update: 2024-05-20 00:17:17 UTC


README

默认错误信息提示

validate验证器提供了默认错误信息规则,详细如下:

private $defaultErrorMsg = [
        'activeUrl'             => ':fieldName必须是可访问的网址',
        'alpha'                 => ':fieldName只能是字母',
        'alphaNum'              => ':fieldName只能是字母和数字',
        'alphaDash'             => ':fieldName只能是字母数字下划线和破折号',
        'between'               => ':fieldName只能在 :arg0 - :arg1 之间',
        'bool'                  => ':fieldName只能是布尔值',
        'decimal'               => ':fieldName只能是小数',
        'dateBefore'            => ':fieldName必须在日期 :arg0 之前',
        'dateAfter'             => ':fieldName必须在日期 :arg0 之后',
        'equal'                 => ':fieldName必须等于:arg0',
        'different'             => ':fieldName必须不等于:arg0',
        'equalWithColumn'       => ':fieldName必须等于:arg0的值',
        'differentWithColumn'   => ':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',
        'betweenLen'            => ':fieldName的长度只能在 :arg0 - :arg1 之间',
        'money'                 => ':fieldName必须是合法的金额',
        'max'                   => ':fieldName的值不能大于:arg0',
        'min'                   => ':fieldName的值不能小于:arg0',
        'regex'                 => ':fieldName不符合指定规则',
        'allDigital'            => ':fieldName只能由数字构成',
        'required'              => ':fieldName必须填写',
        'timestamp'             => ':fieldName必须是一个有效的时间戳',
        'timestampBeforeDate'   => ':fieldName必须在:arg0之前',
        'timestampAfterDate'    => ':fieldName必须在:arg0之后',
        'timestampBefore'       => ':fieldName必须在:arg0之前',
        'timestampAfter'        => ':fieldName必须在:arg0之后',
        'url'                   => ':fieldName必须是合法的网址',
        'allowFile'             => ':fieldName文件扩展名必须在:arg0内',
        'allowFileType'         => ':fieldName文件类型必须在:arg0内',
        'isArray'               => ':fieldName类型必须为数组',
        'lessThanWithColumn'    => ':fieldName必须小于:arg0的值',
        'greaterThanWithColumn' => ':fieldName必须大于:arg0的值'
    ];

默认错误例子

<?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 \Qianlong\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 \Qianlong\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 \Qianlong\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 \Qianlong\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) "手机号格式不正确"
 */