thinkPHP自动验证机制详解

2019-05-02 09:59:58于丽

必须结合create()使用

$User = D("User"); // 实例化User对象
if (!$User->create()){
  // 如果创建失败 表示验证没有通过 输出错误提示信息
exit($User->getError());
}else{
  // 验证通过 可以进行其他数据操作
}

项目实例

//自动验证
protected $_validate = array (
    array('name', 'require', '姓名不能为空!', 1, '', 3),
    array('tel', 'require', '手机号不能为空!', 1, '', 3),
    array('password', 'require', '密码不能为空!', 1, '', 1),
    array('email', 'require', '邮箱不能为空!', 1, '', 3),
    array('ID_number', 'require', '身份证号不能为空!', 1, '', 3),
    array('ID_positive', 'require', '身份证正面照不能为空!', 1, '', 1),
    array('ID_opposite', 'require', '身份证反面照不能为空!', 1, '', 1),
    array('ID_handle', 'require', '手持身份证照不能为空!', 1, '', 1),
    array('bankcard', 'require', '银行卡照片不能为空!', 1, '', 1),
    array('openbank', 'require', '开户行不能为空!', 1, '', 3),
    array('accountname', 'require', '银行账户名不能为空!', 1, '', 3),
    array('bankaccount', 'require', '银行账户号不能为空!', 1, '', 3),
    array('tel', '/^d{11}$/', '手机号不合法!', 1, 'regex', 3),
    array('email', 'email', '邮箱不合法!', 1, '', 3),
    array('ID_number', '/^(d{15}$|^d{18}$|^d{17}(d|X|x))$/', '身份证号不合法!', 1, 'regex', 3),
    array('tel', '', '手机号已经存在!', 1, 'unique', 3), // 新增修改时候验证tel字段是否唯一
    array('email', '', '邮箱已经存在!', 1, 'unique', 3), // email唯一
    array('ID_number', '', '身份证号已经存在!', 1, 'unique', 3), // 身份证号唯一
);

说明,只要定义了Model,在任何地方调用,都会进行验证。很方便。

必须是D方法,才会有效。M方法不会触发自动验证。

更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》、《smarty模板入门基础教程》及《PHP模板技术总结》。

希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

相关文章 大家在看