首頁  >  文章  >  後端開發  >  關於ThinkPHP中create()方法的自動驗證

關於ThinkPHP中create()方法的自動驗證

不言
不言原創
2018-06-08 15:55:511768瀏覽

下面為大家帶來一篇ThinkPHP中create()方法自動驗證實例。內容還挺不錯的,現在就分享給大家,也給大家做個參考。

自動驗證是ThinkPHP模型層提供的一種資料驗證方法,可以在使用create建立資料物件的時候自動進行資料驗證。

原則:

create()方法收集表單($_POST)資訊並返回,同時觸發表單自動驗證,過濾非法字段,

在控制器中使用create()方法,(傳回值為true/false),會自動觸發模型類別中的$_validate屬性(為父類Model中的方法,在子類Model中重寫),在$_validate中自訂驗證規則(驗證規則下面會詳細說明),當create()方法沒有資料即傳回值為false時,透過$xxx物件->getError();取得並回傳錯誤訊息!

使用自動驗證必須按照以下規則格式定義:

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

其中驗證字段,驗證規則,錯誤提示是必填項,驗證條件,附加規則,驗證時間為可選!

驗證欄位(必填):表單欄位。

驗證規則(必填):require 欄位必須、email 信箱、url URL位址、number 數字,也可以結合附加規則使用。

錯誤提示(必填):驗證失敗時傳回的提示訊息。

驗證條件(可選):有0,1,2三種,0:_POST中存在的欄位驗證,預設;1:驗證規則定義了就必須驗證;2:值不為空時驗證.

附加規則:

##in 驗證是否在某個範圍內,定義的驗證規則可以是數組或逗號分割的字串notin驗證是否不在在某個範圍內,定義的驗證規則可以是陣列或逗號分割的字串(3.1.2版本新增)length 驗證長度,定義的驗證規則可以是一個數字(表示固定長度)或數字範圍(例如3,12 表示長度從3到12的範圍)betweennotbetween#expire#ip_allow#ip_deny#unique#

验证时间(可选):共有1,2,3三种,1:新增数据时候验证;2:编辑数据时候验证;3:全部情况下验证(默认);也可以可以根据业务需要增加其他的验证时间

下面附上代码:以注册为例

前台页面比较简单,代码就不贴出来了,下面是前台注册界面截图

控制器代码:

//注册
 public function register(){
  $user = new \Model\UserModel();

  //两个逻辑:收集,展示
  if (!empty($_POST)) {
  
  //create()方法收集表单($_POST)信息并返回,同时触发表单自动验证,过滤非法字段
  $date = $user->create();
  //通过create()方法的返回值$date判断验证是否成功
  if ($date) { //返回实在数据的时候才进行添加
   //implode()把数组变为字符串
   $date['user_hobby'] = implode(',', $date['user_hobby']);
   $info = $user->add($date);
   if ($info) {
   
   //跳转首页   
   $this->redirect('Index/index');
   }
  }else{

   //把错误信息分配到前台模板
   $error = $user->getError();
   $this->assign('error',$error);
  }
  }
  //调用view视图
  $this->display();
 }

模型类代码:

class UserModel extends Model{
 
 //是否批量处理验证,批量获取全部的错误验证信息
 protected $patchValidate = true; //默认为false

 //自动验证定义
 protected $_validate = array(

  //array(字段,验证规则,错误提示,验证条件,附加规则,验证时间)
  //①用户名验证,不能为空
  array('username','require','用户名不能为空'),
  array('username','','该用户名已经被占用','0','unique'),
  //②密码验证,不为空
  array('password','require','密码不能为空'),
  //③验证确认密码,必须填写,与密码保持一致
  array('password2','require','确认密码必须填写'),
  array('password2','password','两次密码保持一致',0,'confirm'),
  //④邮箱验证
  array('user_email','email','邮箱格式不正确',2),
  //⑤qq验证,数字组成,5-12位
  array('user_qq','number','qq必须是数字'),
  array('user_qq','5,12','位数在5-12位之间',0,'length'),
  //⑥学历验证,必须选一个
  array('user_xueli','2,5','学位必须选择一个',0,'between'),
  //⑦爱好验证,必须选择二个以上
  //因为爱好返回的是数组,附加规则中没有可以直接用的规则,所以需自定义方法,用callback方法验证
  array('user_hobby','check_hobby','爱好必须选两项或以上',1,'callback'),
  );

 //定义方法进行爱好验证
 //参数$arg代表被验证的表单信息
 function check_hobby($arg)
 {
  //判断数组长度是否大于2
  if (count($arg)<2) {
   return false; //会自动输出验证错误信息
  }
  return true;
 }
}

把验证的错误信息在模板中给展示出来(部分代码)

<td style="width:13%; text-align: right;">
 <label for="User_username" class="required">用户名 
 <span>*</span></label>
</td>

<td style="width:87%;">
 <input class="inputBg" size="25" name="username" id="User_username" type="text" value="" />     
 <span style="color:red;"><{$error.username|default:""}></span>
</td>

结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

对THINKPHP的addAll支持的最大数据量的分析

关于ThinkPHP CURD方法之table方法

关于ThinkPHP利用getlist方法实现数据搜索功能的分析

#regex 正規驗證,定義的驗證規則是一個正規表示式(預設)
function 函數驗證,定義的驗證規則是一個函數名稱
callback 方法驗證,定義的驗證規則是目前模型類別的一個方法
#confirm 驗證表單中的兩個欄位是否相同,定義的驗證規則是一個欄位名稱
equal #驗證是否等於某個值,該值由前面的驗證規則定義
notequal 驗證是否不等於某個值,該值由前面的驗證規則定義(3.1.2版本新增)
##驗證範圍,定義的驗證規則表示範圍,可以使用字串或數組,例如1,31或array(1,31)
驗證不在某個範圍,定義的驗證規則表示範圍,可以使用字串或陣列(3.1.2版本新增)
驗證是否在有效期,定義的驗證規則表示時間範圍,可以到時間,例如可以使用2012-1-15,2013-1-15 表示目前提交有效期限在2012-1-15到2013-1-15之間,也可以使用時間戳定義
驗證IP是否允許,定義的驗證規則表示允許的IP位址列表,用逗號分隔,例如201.12.2.5,201.12.2.6
驗證IP是否禁止,定義的驗證規則表示禁止的ip位址列表,用逗號分隔,例如201.12.2.5,201.12.2.6
驗證是否唯一,系統會根據欄位目前的值查詢資料庫來判斷是否存在相同的值,當表單資料包含主鍵欄位時unique不可用於判斷主鍵欄位本身

以上是關於ThinkPHP中create()方法的自動驗證的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn