thinkphp-自动验证

      Home或Home2\Controller  编辑下的

/* //静态验证
//自动验证
$user=D(‘Sks‘);
$data[‘name‘]=‘1234‘;
$data[‘pass‘]=‘xxx‘;
//$data[‘name2‘]=‘xxx‘;
if($user->create($data)){

echo ‘<br>‘;
echo ‘所有数据成功‘;
}
else{
//输出错误信息

echo ‘<br>‘;
echo ‘<pre>‘;
var_dump($user->getError());
echo ‘</pre>‘;
}
*/

/* //动态验证
$rules=array(
array(‘name‘,‘require‘,‘用户名不得为空‘),
);
$user=M(‘Sks‘);
$data[‘name‘]=‘1234‘;
if($user->validate($rules)->create($data)){

echo ‘<br>‘;
echo ‘所有数据成功‘;
}
else{
//输出错误信息

echo ‘<br>‘;
echo ‘<pre>‘;
var_dump($user->getError());
echo ‘</pre>‘;
}
*/

      Home或Home2\Model  下的

protected $patchValidate=true;
//原本如果有多个错误,只显示一个,但这个会令其都显示
protected $_validate=array(
//字段名,验证规则,错误提示,验证条件,附加规则,验证时间

//array(‘name‘,‘require‘,‘用户不得为空‘,‘0‘,‘regex‘,‘3‘),

//name字段,不得空,错误提示:上,(存在字段就验证,附加规则,添加或修改时验证)默认项

//array(‘name‘,‘email‘,‘邮箱‘),

//array(‘name‘,‘url‘,‘url‘),

//array(‘name‘,‘currency‘,‘货币‘),

//array(‘name‘,‘zip‘,‘邮政编码‘),

//array(‘name‘,‘number‘,‘正整数‘),

//array(‘name‘,‘integer‘,‘整数‘),

//array(‘name‘,‘double‘,‘浮点数‘),

//array(‘name‘,‘english‘,‘纯英语‘),

//附加规则-不用内置规则,自己定的规则

//array(‘name‘,‘/^\d{3,6}$/‘,‘3-6位数字‘,0,‘regex‘),
//验证3-6位数

//array(‘name‘,‘xxx‘,‘值不相等‘,0,‘equal‘),
//验证是否与指定值相等

//array(‘pass‘,‘xxx‘,‘值不能相等‘,0,‘notequal‘),
//验证是否与指定值不相等

//array(‘name‘,‘name2‘,‘两个用户名不同‘,0,‘confirm‘),
//验证两个字段是否相等

//array(‘name‘,array(1,2,3),‘不是指定值‘,0,‘in‘),
//array(‘name‘,‘张三,李四,王五‘,‘不是指定值‘,0,‘in‘),
//验证数值是否是指定值

//array(‘name‘,array(1,3),‘不得是指定值‘,0,‘notin‘),
//array(‘name‘,‘张三,李四,王五‘,‘不得是指定值‘,0,‘notin‘),
//验证数值是否不是指定值

//array(‘name‘,‘3‘,‘请输入三位数‘,0,‘length‘),
//array(‘name‘,‘3,5‘,‘不得小于三位,不得大于五位‘,0,‘length‘),
//验证数值的位数

//array(‘name‘,array(3,5),‘不在指定范围内‘,0,‘between‘),
//array(‘name‘,‘3,5‘,‘不在指定范围内‘,0,‘between‘),
//验证数值的位数

//array(‘name‘,array(3,5),‘不得在指定范围内‘,0,‘notbetween‘),
//array(‘name‘,‘3,5‘,‘不得在指定范围内‘,0,‘notbetween‘),
//验证数值的位数

//array(‘name‘,‘2017-4-10,2017-4-13‘,‘已过期‘,0,‘expire‘),
//设置有效期范围,必须是表单提交有效,可以是时间戳

//array(‘name‘,‘192.168.0.10‘,‘当前ip被禁止‘,0,‘ip_deny‘),
//禁止ip访问

//array(‘name‘,‘127.0.0.1‘,‘当前ip没有被允许‘,0,‘ip_allow‘),
//只允许此ip访问

//array(‘name‘,‘checkLength‘,‘用户名必须为3-5位‘,0,‘callback‘,3,array(3,5)),
//使用回调形式

//array(‘name‘,‘checkLength‘,‘用户名必须为3-5位‘,0,‘callback‘,3,array(3,5)),
//使用函数形式

);
/* //checkLength回调形式
protected function checkLength($str,$min,$max){
preg_match_all("/./u",$str,$matches);
$len=count($matches[0]);
if($len<$min || $len>$max){
return false;
}
else{
return true;
}
}
*/

时间: 2024-08-05 09:45:02

thinkphp-自动验证的相关文章

ThinkPHP 自动验证与自动填充无效可能的原因

原文链接:http://www.5idev.com/p-thinkphp_validate_auto_Invalid.shtml 自动验证与自动填充是在使用ThinkPHP时经常用到的功能,但偶尔会遇到自动验证与自动填充无效的情况,本文就ThinkPHP 自动验证与自动填充无效可能的原因做一些分析. create() ThinkPHP 自动验证与自动填充是在创建数据对象 create() 时实现的,因此自动验证与自动填充无效很大程度上与 create() 有关. create 方法语法如下: c

thinkphp自动验证无效的问题

新手入门thinkphp,试用自动验证表单输入数据功能,却发现怎么都不能调用自动验证,自动验证无效,原因竟是一个小细节的疏忽,学习一定要细心啊! Action方法: IndexAction下的adds方法,D(“Liuyan”)获取post提交过来的内容,create()方法创建数据对象,D方法创建了数据对象才可以自动调用验证. public function adds(){ $ly=D("liuyan"); $result=$ly->create(); if($result){

&lt;转&gt;thinkphp自动验证无效的问题

新手入门thinkphp,试用自动验证表单输入数据功能,却发现怎么都不能调用自动验证,自动验证无效,原因竟是一个小细节的疏忽,学习一定要细心啊! Action方法: IndexAction下的adds方法,D(“Liuyan”)获取post提交过来的内容,create()方法创建数据对象,D方法创建了数据对象才可以自动调用验证. public function adds(){ $ly=D("liuyan"); $result=$ly->create(); if($result){

thinkphp自动验证

1.thinkphp的自动验证 自动验证是ThinkPHP模型层提供的一种数据验证方法,可以在使用create创建数据对象的时候自动进行数据验证. 1.1应用范围: 进行数据类型.业务规则.安全判断等方面的验证. 1.2验证方式: 1.静态方式:在模型类里面通过$_validate属性定义验证规则. 2.动态方式:使用模型类的validate方法动态创建自动验证规则. 1.3验证规则: 例:一个简单的注册信息时的自动验证: <?php namespace Home\Model; use Thin

thinkphp自动验证和自动完成

tp验证码的自动验证小案例 模板文件 <form action="" method="post"> <p> User: <input type="text" name="name1" id=""> </p> <p> PASS: <input type="password" name="pass1" id

Thinkphp自动验证规则

其实说白了,这篇文章就是转给自己看的,省的下次用的时候满网络找了.有需要的同学也可以看看.自动验证是非常有用的一个技术.平常的验证基本就是,用户名是否为空,用户名是否重复,密码,重复密码是否一致.官方给的就是这些.那么我们不可能只用到这些,铁定还有别的规则,所以下面这些规则供同学借鉴,也供我自己借鉴. array(‘name’,’/^[a-z]\w{3,}$/i’,’名字不符合要求!’);array(‘password’,’/^[a-z]\w{6,30}$/i’,’密码不符合要求!’);arra

thinkphp自动验证中的静态验证和动态验证和批量验证

1.静态定义 在模型类里面预先定义好该模型的自动验证规则,我们称为静态定义. 举例说明,我们在模型类里面定义了$_validate属性如下: class UserModel extends Model{ protected $_validate = array( array('verify','require','验证码必须!'), //默认情况下用正则进行验证 array('name','','帐号名称已经存在!',0,'unique',1), // 在新增的时候验证name字段是否唯一 ar

ThinkPHP自动验证分析

今天一起来学习下TP的自动验证具体是怎么实现的,首先验证规则的定义格式如下: // 验证因子定义格式 array(field,rule,message,condition,type,when,params) field:验证字段的名称 rule:验证表达式 message:错误信息 condition:验证条件,0存在就验证 1 必须验证 2值不为空时验证 type:验证方式 when:什么时候验证 1插入时 2 更新时 3两种情况都验证 params:额外参数,当验证规则类型为function

thinkphp自动验证方法的使用

建一个表单: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <form action="{:U('Index/check')}" method='post'> <table>

ThinkPHP 自动验证相关注意

1.假如加入了表单令牌的话,表单的各种名与对应Model字段一致,不然报坑爹的令牌错误. 2.假如加入了表单令牌的话,Create只能采用默认的POST数据创建数据对象,不然又是坑爹的令牌错误. 3.create方法的第二个参数可以指定创建数据的操作状态,默认情况下是自动判断是写入还是更新操作. 也可以显式指定操作状态,例如: $Member = M("User"); // 指定更新数据操作状态 $Member->create($_POST,Model::MODEL_UPDATE