昨天晚上我们老大叫我弄表单自动验证功能,愁了半天借鉴了好多官网的知识,才出来,诶,总之分享一下我自己的成果吧!
thinkphp 在Model基类为我们定义了自动验证的函数和正则表达式,我们只需要在对应的数据库表的模型类下建立$_validate属性就可以了。
1、我们找到Model基类,可以看到 protected $_validate = array(); // 自动验证定,它是数组类型的,下面在对应数据模型文件定义它;
2、
代码如下:
public function CheckVerify($verify) {
if (md5($verify) != Session::get('verify')) return false;
return true;
}
//自动验证
代码如下:
protected $_validate = array(
array("title", "require", "标题必须!"),
array('categoryId', 'require', "类别必须!"),
array('content', 'require', "内容必须!"),
array('verify', 'require','验证码必须!'),
array('verify', 'CheckVerify', '验证码错误!', 0, 'callback')
);
3、格式说明:array(验证字段,验证规则,错误提示,验证条件,附加规则,验证时间),
4、参数解释:
验证字段:需要验证的表单字段名称,这个字段不一定是数据库字段,也可以是表单的一些辅助字段,例如确认密码和验证码等等。
验证规则: 要进行验证的规则,需要结合附加规则(必须),官方已经包含的规则如下(自己同时也可以加):
代码如下:
$validate = array(
'require'=> '/.+/',
'email' => '/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/',
'url' => '/^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&_~`@[\]\':+!]*([^\"\"])*$/',
'currency' => '/^\d+(\.\d+)?$/',
'number' => '/^\d+$/',
'zip' => '/^[1-9]\d{5}$/',
'integer' => '/^[-\+]?\d+$/',
'double' => '/^[-\+]?\d+(\.\d+)?$/',
'english' => '/^[A-Za-z]+$/',
);
提示信息: 用于验证失败后的提示信息定义(必须)、
验证条件:(可选)
验证条件的规则有三条:
Model::EXISTS_TO_VAILIDATE 或者0 存在字段就验证 (默认)
Model::MUST_TO_VALIDATE 或者1 必须验证
Model::VALUE_TO_VAILIDATE或者2 值不为空的时候验证
附加规则:
regex 正则验证,说明前面的那个验证规则是一个正则表达式;
function 使用函数验证,说明前面的那个验证是个函数名;
callback 使用方法验证,说明验证规则是一个Model类的方法;
confirm 验证表单中的两个字段是否相等,验证规则是一个字段名;
equal 验证是否等于某个值,这个值是有前面的验证规则定义的;
in 验证是否在某个范围之内,前面定义的是一个数组;
unique 验证是否唯一,系统会根据字段目前的值查询数据库来判断时候存在相同的值;
同时,系统还内置了一些常用的正则验证规则,可以这节使用,包括:require字段必须,email 邮箱;
currency 货币,number 数字,这些验证规则可以直接使用;
验证时间:(可选)
01.Model:: MODEL_INSERT 或者1新增数据时候验证
02.Model:: MODEL_UPDATE 或者2编辑数据时候验证
03.Model:: MODEL_BOTH 或者3 全部情况下验证(默认)
5、官方示例:
代码如下:
protected $_validate = array(
array('verify','require','验证码必须!'), //默认情况下用正则进行验证
array(name,'','帐号名称已经存在!',0,'unique',1), // 在新增的时候验证name字段是否唯一
array('value',array(1,2,3),'值的范围不正确!',2,'in'), // 当值不为空的时候判断是否在一个范围内
array('repassword','password','确认密码不正确',0,'confirm'), // 验证确认密码是否和密码一致
array('password','checkPwd','密码格式不正确',0,'function')// 自定义函数验证密码格式
);
也不知道符合我们老大的要求不,总之还算是出来了,好辛苦啊!! 大晚上的找代码,找案例,求安慰!!

thinkphp是国产框架。ThinkPHP是一个快速、兼容而且简单的轻量级国产PHP开发框架,是为了简化企业级应用开发和敏捷WEB应用开发而诞生的。ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。

本篇文章给大家带来了关于thinkphp的相关知识,其中主要介绍了关于使用think-queue来实现普通队列和延迟队列的相关内容,think-queue是thinkphp官方提供的一个消息队列服务,下面一起来看一下,希望对大家有帮助。

thinkphp基于的mvc分别是指:1、m是model的缩写,表示模型,用于数据处理;2、v是view的缩写,表示视图,由View类和模板文件组成;3、c是controller的缩写,表示控制器,用于逻辑处理。mvc设计模式是一种编程思想,是一种将应用程序的逻辑层和表现层进行分离的方法。

本篇文章给大家带来了关于thinkphp的相关知识,其中主要介绍了使用jwt认证的问题,下面一起来看一下,希望对大家有帮助。

thinkphp扩展有:1、think-migration,是一种数据库迁移工具;2、think-orm,是一种ORM类库扩展;3、think-oracle,是一种Oracle驱动扩展;4、think-mongo,一种MongoDb扩展;5、think-soar,一种SQL语句优化扩展;6、porter,一种数据库管理工具;7、tp-jwt-auth,一个jwt身份验证扩展包。

thinkphp查询库是否存在的方法:1、打开相应的tp文件;2、通过“ $isTable=db()->query('SHOW TABLES LIKE '."'".$data['table_name']."'");if($isTable){...}else{...}”方式验证表是否存在即可。

本篇文章给大家带来了关于ThinkPHP的相关知识,其中主要整理了使用think-queue实现redis消息队列的相关问题,下面一起来看一下,希望对大家有帮助。

在thinkphp3.2中,可以利用define关闭调试模式,该标签用于变量和常量的定义,将入口文件中定义调试模式设为FALSE即可,语法为“define('APP_DEBUG', false);”;开启调试模式将参数值设置为true即可。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

Atom編輯器mac版下載
最受歡迎的的開源編輯器

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Dreamweaver Mac版
視覺化網頁開發工具