• 技术文章 >php框架 >ThinkPHP

    详解ThinkPHP中自动验证及验证规则

    angryTomangryTom2020-03-23 14:54:22转载1740
    本篇文章详细介绍了thinkphp中自动验证及验证规则的方法,希望对学习thinkphp的朋友有帮助!

    详解ThinkPHP中自动验证及验证规则

    ThinkPHP 内置了数据对象的自动验证功能来完成模型的业务规则验证。自动验证是基于数据对象的,而大多情况下数据对象是基于 $_POST表单 (不是绝对的)创建的。

    基本的自动验证功能包括:必须字段、email邮箱格式、唯一性、URL地址、数字、两个字段是否相同、是否等于某个值等。

    要使用系统的自动验证功能,只需要在对应的 Model类 里面定义 $_validate 属性(由多个验证因子组成的数组),语法如下:

    protected $_validate = array(
        array(验证字段,验证规则,错误提示[,验证条件][,附加规则][,验证时间])
    };

    (推荐教程:thinkphp教程

    ThinkPHP自动验证格式说明:
    验证因子说明
    验证字段必须。需要验证的表单字段名称,这个字段不一定是数据库字段,也可以是表单的一些辅助字段,例如验证码等。
    验证规则必须。要进行验证的规则,需要联合附加规则一起使用。
    错误提示必须。当验证不通过时的提示信息。
    验证条件可选。包括:
    1. Model::EXISTS_TO_VAILIDATE 或者 0 :存在字段就验证(默认)
    2. Model::MUST_TO_VALIDATE 或者 1 :必须验证
    3. Model::VALUE_TO_VAILIDATE 或者 2 :值不为空的时候验证
    附加规则可选。配合验证规则使用,包括:
    1. regex:使用正则进行验证,表示前面定义的验证规则是一个正则表达式(默认)
    2. unique:验证唯一性,系统会根据字段目前的值查询数据库来判断是否存在相同的值
    3. confirm:验证表单中的两个字段是否相同,前面定义的验证规则是一个字段名
    4. equal:验证是否等于某个值,该值由前面的验证规则定义
    5. in:验证是否在某个范围内,前面定义的验证规则必须是一个数组
    6. function:使用函数验证,表示前面定义的验证规则是一个函数名
    7. callback:使用方法验证,前面定义的验证规则是当前 Model 类的一个方法
    验证时间可选。包括:
    1. Model:: MODEL_INSERT 或者 1 :新增数据时候验证
    2. Model:: MODEL_UPDATE 或者 2 :编辑数据时候验证
    3. Model:: MODEL_BOTH 或者 3 :全部情况下验证(默认)

    自动验证例子

    下面的例子验证文章标题必须填写且检测标题是否已存在:

    class ArticleModel extends Model{
        protected $_validate = array(
            array('title','require','标题不能为空!'),
            array('title','','标题已经存在!',0,'unique',1),
        };
    }

    在操作中,当使用 create 方法创建数据对象时会自动进行数据验证操作(当 POST 提交表单处理时):

    $Article = D("Article");
    if (!$Article->create()){
        // 如果创建失败,表示验证没有通过(注:可能原因之一)输出错误提示信息
        exit($Article->getError());
    }else{
        // 验证通过,继续下一步流程如将数据写入数据表
    }

    系统内置了一些常用正则验证的规则,包括:require(必须)、email(邮箱格式)、url(URL地址)、currency(货币)、number(数字)、qq(QQ号码)、english(英文字符),可以直接使用。

    出于用户体验考虑,$Article->getError() 返回的错误提示信息,一般以 Ajax 方式返回,详细参见《ThinkPHP Ajax》。

    定义自己的验证规则

    当内置的这些验证规则无法满足验证要求是,可以定义自己的验证规则,如要求出生年月以 2000-1-1 格式输入时:

    array('birthday','/^d{4}-d{1,2}-d{1,2}$/','出生年月格式错误!'),

    更多相关教程,请关注PHP中文网

    以上就是详解ThinkPHP中自动验证及验证规则的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:CSDN,如有侵犯,请联系admin@php.cn删除
    上一篇:ThinkPHP5自定义分页URL 下一篇:Thinkphp使用join联表查询的方法
    大前端线上培训班

    相关文章推荐

    • thinkPHP 表单自动验证功能• ThinkPHP框架项目开发专题--自动验证• ThinkPHP3.1新特性动态设置自动完成及自动验证的介绍• [php] 用composer自动验证同时获取gitlab的私有库的方法

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网