下面為大家帶來一篇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:值不為空時驗證.
附加規則:
#regex | 正規驗證,定義的驗證規則是一個正規表示式(預設) |
function | 函數驗證,定義的驗證規則是一個函數名稱 |
callback | 方法驗證,定義的驗證規則是目前模型類別的一個方法 |
#confirm | 驗證表單中的兩個欄位是否相同,定義的驗證規則是一個欄位名稱 |
equal | #驗證是否等於某個值,該值由前面的驗證規則定義 |
notequal | 驗證是否不等於某個值,該值由前面的驗證規則定義(3.1.2版本新增) |
驗證是否在某個範圍內,定義的驗證規則可以是數組或逗號分割的字串 | |
驗證是否不在在某個範圍內,定義的驗證規則可以是陣列或逗號分割的字串(3.1.2版本新增) | |
驗證長度,定義的驗證規則可以是一個數字(表示固定長度)或數字範圍(例如3,12 表示長度從3到12的範圍) | |
##驗證範圍,定義的驗證規則表示範圍,可以使用字串或數組,例如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不可用於判斷主鍵欄位本身 |