小編給大家分享一下Yii核心驗(yàn)證器api的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)自成立以來,一直致力于為企業(yè)提供從網(wǎng)站策劃、網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、電子商務(wù)、網(wǎng)站推廣、網(wǎng)站優(yōu)化到為企業(yè)提供個(gè)性化軟件開發(fā)等基于互聯(lián)網(wǎng)的全面整合營銷服務(wù)。公司擁有豐富的網(wǎng)站建設(shè)和互聯(lián)網(wǎng)應(yīng)用系統(tǒng)開發(fā)管理經(jīng)驗(yàn)、成熟的應(yīng)用系統(tǒng)解決方案、優(yōu)秀的網(wǎng)站開發(fā)工程師團(tuán)隊(duì)及專業(yè)的網(wǎng)站設(shè)計(jì)師團(tuán)隊(duì)。具體如下:
核心驗(yàn)證器 Core Validators
前言
Yii 提供了一系列常用的核心 validators, 你可在
yii\validators namespace 中找到. 不用使用長的驗(yàn)證器類名, 你可以使用別名代替他們.
例如, 你可以使用別名 required 代替 yii\validators\RequiredValidator 類:
這個(gè) yii\validators\Validator::$builtInValidators 屬性生命所有支持的驗(yàn)證器的別名.
接下來, 我們將講解每種核心驗(yàn)證器的用法.
1. boolean 對(duì)錯(cuò)值
true, 'falseValue' => false, 'strict' => true], ] ?>
上面檢測(cè)是否是一個(gè)bool值.
trueValue: 代表true時(shí)的值. 默認(rèn)為 '1'.
falseValue: 代表 false 時(shí)的值. 默認(rèn)為 '0'.
strict: 是否輸入框中的值必須匹配 設(shè)置的 trueValue 和 falseValue. 默認(rèn)為 false.
注意: 因?yàn)閿?shù)據(jù)提交通過HTML形式都是字符創(chuàng), 一般你需要設(shè)置 strict 屬性為 false.
2. captcha 驗(yàn)證碼
這個(gè)驗(yàn)證器通常和
yii\captcha\CaptchaAction 以及
yii\captcha\Captcha 一起使用以確保輸入的是相同的驗(yàn)證碼 通過 CAPTCHA 組件.
caseSensitive: 是否驗(yàn)證碼需要區(qū)分大小寫. 默認(rèn)為 false.
captchaAction: 默認(rèn)的驗(yàn)證碼的 CAPTCHA action 生成 CAPTCHA image的路徑. 默認(rèn)為 'site/captcha'.
skipOnEmpty: 輸入為空的時(shí)候是否跳過驗(yàn)證. 默認(rèn)false, 即 input 輸入是必須的.
3. compare 比較
= 30 ['age', 'compare', 'compareValue' => 30, 'operator' => '>='], ] ?>
這個(gè)驗(yàn)證器比較指定的輸入值和另一個(gè)值確保他們之間使用指定的操作符.
compareAttribute: 屬性的名字即將會(huì)和誰比較.當(dāng)驗(yàn)證器被用來驗(yàn)證一個(gè)屬性的時(shí)候, 他會(huì)和屬性名字相同 但帶有后綴 _repeat的屬性相比較. 例如, 如果要驗(yàn)證的屬性名是 password, 那么默認(rèn)對(duì)比的屬性名就是 password_repeat 你可以指定你想要的值.
compareValue: 一個(gè)和輸入值比較的常量值. 當(dāng) property 和 compareAttribute 屬性被同時(shí)指定的時(shí)候, 這個(gè)值將優(yōu)先.
operator: 比較的操作符. 默認(rèn)是 ==, 即輸入值和 compareAttribute 或 compareValue 值相等的時(shí)候才會(huì)成功.
支持下面這些操作符: ==、===、!=、!==、>、>=、<、<=。
4. date 日期
這個(gè)驗(yàn)證器檢查輸入的值是一個(gè)日期date, 時(shí)間time 或者datetime 以一個(gè)合適的形式. 可選的,他能轉(zhuǎn)換輸入值成為一個(gè)UNIX時(shí)間戳存儲(chǔ)在一個(gè)通過timestampAttribute 指定的屬性里.
format: 這個(gè) date/time 是 /tupian/20230522/datetime.createfromformat.php 中聲明的所有支持的格式
如果這個(gè)值沒有設(shè)置, 他會(huì)自動(dòng)取值 Yii::$app->formatter->dateFormat.
timestampAttribute: 屬性名用來存儲(chǔ)轉(zhuǎn)換將輸入的日期或時(shí)間. 也可以是相同的屬性名作為被驗(yàn)證過的. 如果是這種情況, 原始的值將會(huì)被時(shí)間戳重寫. 你可以看看 "如何處理日期選擇器 DatePicker" 用例子.
http://www.yiiframework.com/doc-2.0/widget-jui#datepicker-date-input
如果輸入的是可選的,你也可能要添加一個(gè)默認(rèn)值濾波器除了日期驗(yàn)證,以確保空輸入存儲(chǔ)為NULL。否則你可能最終得到的日期像日期選擇器的輸入字段在0000-00-00 或 您的數(shù)據(jù)庫1970-01-01.
null], [['from_date', 'to_date'], 'date'], ], ?>
5.default 默認(rèn)值
null], // 設(shè)置 "country" 為 "USA" 如果他是空的 ['country', 'default', 'value' => 'USA'], // 分配 "from" 和 "to" 分別加3天和6天, 如果他們是空的話 [['from', 'to'], 'default', 'value' => function ($model, $attribute) { return date('Y-m-d', strtotime($attribute === 'to' ? '+3 days' : '+6 days')); }], ] ?>
這個(gè)驗(yàn)證器不驗(yàn)證數(shù)據(jù). 當(dāng)他們?yōu)榭盏臅r(shí)候.分配給屬性值。
value: 表單的默認(rèn)值 函數(shù)原型如下,
6. double 浮點(diǎn)值
相當(dāng)于一個(gè)數(shù)字驗(yàn)證器:
max: 數(shù)字上限,沒設(shè)置不檢查
min: 數(shù)字下線,沒設(shè)置不檢查
7. email 郵箱驗(yàn)證
allowName: 檢查名字是否允許在郵箱中出現(xiàn) (e.g. John Smith
checkDNS,是否檢查電子郵件的域名是否存在,是否有任何一個(gè)A或MX記錄。請(qǐng)注意,這可能檢查由于臨時(shí)DNS問題失敗,即使電子郵件地址實(shí)際上是有效的。默認(rèn)為false。
enableIDN,驗(yàn)證過程是否應(yīng)考慮到IDN(國際化域名)。默認(rèn)為false。需要注意的是,為了使用IDN驗(yàn)證您必須安裝并啟用國際PHP擴(kuò)展,或異常將被拋出。
8. exist 是否存在
'a2'], // a1 和 a2 需要同時(shí)存在, 他們都將接收錯(cuò)誤信息 [['a1', 'a2'], 'exist', 'targetAttribute' => ['a1', 'a2']], // a1 和 a2 需要同時(shí)存在, 只有 a1 將接收錯(cuò)誤信息 ['a1', 'exist', 'targetAttribute' => ['a1', 'a2']], // a1 需要存在 通過檢測(cè)a2 和 a3 (用 a1 的值) ['a1', 'exist', 'targetAttribute' => ['a2', 'a1' => 'a3']], // a1 需要存在. 如果 a1是一個(gè)數(shù)組, 那么每個(gè)元素都必須存在. ['a1', 'exist', 'allowArray' => true], ] ?>
這個(gè)驗(yàn)證器檢查輸入的值能否被找到在在對(duì)應(yīng)的表的列值里,他只會(huì)在 Active Record model 模型的屬性里起作用.
他支持驗(yàn)證單列或多列
targetClass: 用來尋找輸入值驗(yàn)證的 Active Record 類名. 如果未設(shè)置, 默認(rèn)使用當(dāng)前設(shè)置的模型類.
targetAttribute: 應(yīng)該用于驗(yàn)證輸入值的存在在targetClass的屬性的名稱。如果沒有設(shè)置,將使用目前正在驗(yàn)證的屬性的名稱??梢允褂藐嚵衼眚?yàn)證多列的存在的同時(shí)。數(shù)組的值是將被用于驗(yàn)證存在的屬性,而數(shù)組鍵是其值要驗(yàn)證的屬性。如果鍵和值都是一樣的,你可以指定值.
filter: additional filter to be applied to the DB query used to check the existence of the input value. This can be a string or an array representing the additional query condition (refer to yii\db\Query::where() on the format of query condition), or an anonymous function with the signature function ($query), where $query is the Query object that you can modify in the function.
allowArray: 是否允許輸入的值是一個(gè)array.默認(rèn) false. 若果屬性是 true 而且輸入是一個(gè) array, 那么熟這里的每一個(gè)元素都必須存在在指向的目標(biāo)列里. 注意這個(gè)屬性不能被設(shè)置成true 如果你設(shè)置驗(yàn)證多列通過設(shè)置 targetAttribute 為一個(gè) array.
9. file 文件驗(yàn)證
['png', 'jpg', 'gif'], 'maxSize' => 1024*1024], ] ?>
檢查是否是一個(gè)有效的上傳文件。
extensions: 允許上傳的文件類型列表.他可以是一個(gè)數(shù)組 或者是一個(gè)以逗號(hào)分割的字符串(如. "gif, jpg"). 擴(kuò)展名不區(qū)分大小寫,默認(rèn)為 null, 意味著所有的文件擴(kuò)展名是允許的.
mimeTypes: 允許上傳的文件資源的媒體類型。他可以是一個(gè)數(shù)組 或者是一個(gè)以逗號(hào)或空格分割的字符串 (如. "image/jpeg, image/png"). 不區(qū)分大小寫,默認(rèn)為 null, 意味著所有的文件擴(kuò)展名是允許的.
minSize: 上傳文件的最小字節(jié)數(shù) 未設(shè)不做判斷.
maxSize: 上傳文件的較大字節(jié)數(shù) 未設(shè)不做判斷.
maxFiles: 較大的上傳文件數(shù) 默認(rèn)為 1, 意味著只能上傳單個(gè)文件對(duì)于單個(gè)文件上傳框. 如果大于 1, 那么 input必須是一個(gè) array 包含至多 maxFiles 數(shù)量的上傳文件.
checkExtensionByMimeType: 是否檢查文件的擴(kuò)展名. 如果由MIME類型檢查所產(chǎn)生的擴(kuò)展不同于上傳的文件擴(kuò)展名,該文件將被認(rèn)為是無效的。默認(rèn)值為true,意思進(jìn)行這樣的檢查。
FileValidator 和 yii\web\UploadedFile 一起使用. .
文件上傳請(qǐng)參考:http://www.yiiframework.com/doc-2.0/guide-input-file-upload.html
10. filter 過濾
'trim', 'skipOnArray' => true], // 驗(yàn)證正常 "phone" 輸入 ['phone', 'filter', 'filter' => function ($value) { // 驗(yàn)證正確性手機(jī)代碼 return $value; }], ] ?>
這個(gè)驗(yàn)證器驗(yàn)證不了數(shù)據(jù). 相反的, it applies a filter on the input value and assigns it back to the attribute being validated.
filter: 一個(gè)php回調(diào)函數(shù)定義一個(gè)filter. 他可能是一個(gè)全局函數(shù)的名字, 一個(gè)匿名函數(shù)等等. 函數(shù)的原型一定是這個(gè)屬性必須設(shè)置.
skipOnArray: 當(dāng)輸入只是一個(gè)數(shù)組的時(shí)候是否跳過.默認(rèn)是 false. 請(qǐng)注意,如果過濾器無法處理數(shù)組輸入,您應(yīng)該將此屬性設(shè)置為true。否則,可能會(huì)發(fā)生一些PHP錯(cuò)誤.
小提示: 去空格直接用trim驗(yàn)證.
小提示: 部分封裝可以直接使用系統(tǒng)函數(shù)如intval:
'boolval'], ['property', 'filter', 'filter' => 'intval'], ?>
11. image 圖片
'png, jpg', 'minWidth' => 100, 'maxWidth' => 1000, 'minHeight' => 100, 'maxHeight' => 1000, ], ] ?>
文件驗(yàn)證器的擴(kuò)展:
minWidth: 最小的寬度 不設(shè)無限制.
maxWidth: 較大的寬度 不設(shè)無限制.
minHeight: 最小的高度 不設(shè)無限制.
maxHeight: 較大的高度 不設(shè)無限制.
12. in 在那一個(gè)數(shù)組里面的值
[1, 2, 3]], ] ?>
檢查輸入的值是否存在于給定的系列值的列表中.
range: 給定范圍值的列表.
strict: 輸入值和給定值之間的比較結(jié)果是否應(yīng)嚴(yán)格(的類型和值必須相同)。默認(rèn)為false。
not: 驗(yàn)證結(jié)果是否應(yīng)該被反轉(zhuǎn)。默認(rèn)為false。當(dāng)此屬性設(shè)置為true,驗(yàn)證檢查,輸入的值不能是給定列表的值中.
allowArray: 是否允許輸入值是一個(gè)數(shù)組。如果這是真的,并輸入值是一個(gè)數(shù)組,數(shù)組中的每個(gè)元素必須值的給定列表中找到,或驗(yàn)證會(huì)失敗。
13. integer 整型驗(yàn)證
max: 上限 不設(shè)不檢查.
min: 下限 不設(shè)不檢查..
14. match 正則匹配檢查
'/^[a-z]\w*$/i'] ] ?>
輸入值指定的正則表達(dá)式匹配驗(yàn)證檢查.
pattern: 輸入值必須匹配的規(guī)則. 屬性必須設(shè)置,否則將會(huì)拋出異常.
not: 是否反轉(zhuǎn)驗(yàn)證結(jié)果. 默認(rèn) false.
15. number 數(shù)字檢查
相當(dāng)于double驗(yàn)證器.
max: 上限 不設(shè)不檢查.
min: 下限 不設(shè)不檢查.
16. required 是否為空檢查
該驗(yàn)證器阻止用戶提交空的表單數(shù)據(jù).
requiredValue: 應(yīng)該輸入的值. 如果未設(shè) 意味著輸入值 不應(yīng)該為空.
strict: 驗(yàn)證一個(gè)值時(shí)是否應(yīng)該檢查數(shù)據(jù)類型. 默認(rèn)false.當(dāng) requiredValue未設(shè)置時(shí),如果這個(gè)屬性是 true, 驗(yàn)證器會(huì)檢查輸入值不嚴(yán)格null;如果改屬性false,驗(yàn)證器將使用一個(gè)松散的規(guī)則來確定一個(gè)值是空的或不. 當(dāng) requiredValue設(shè)置了,輸入和requiredValue之間的比較也將檢查數(shù)據(jù)類型,如果此屬性為true。
17. safe 標(biāo)記輸入是安全屬性
這個(gè)驗(yàn)證器不會(huì)執(zhí)行數(shù)據(jù)驗(yàn)證.相反, 它是用來標(biāo)記的屬性是一個(gè)安全屬性(我猜作用是不會(huì)進(jìn)行字符轉(zhuǎn)義吧)。
18. string 字符串驗(yàn)證
[4, 24]], ] ?>
這個(gè)驗(yàn)證器檢查輸入的值是一個(gè)字符串且長度在確定的值的范圍里。
length: 指定待驗(yàn)證的字符串的長度. 可以指定以下形式:
一個(gè)整數(shù): 字符串的精確長度;
單個(gè)數(shù)組元素: 輸入的最小長度 (e.g. [8]). 必須超過或等于這個(gè)數(shù)
兩個(gè)數(shù)組元素: 輸入的最小長度和較大長度 (e.g. [8, 128]).
min: 輸入字符串的最小長度 未設(shè)不限制.
max: 輸入字符串的較大長度 未設(shè)不限制..
encoding: 輸入字符串的編碼 未設(shè)默認(rèn) UTF-8.
19. trim 去空格
不進(jìn)行數(shù)據(jù)驗(yàn)證 只進(jìn)行去空格 如果屬性是一個(gè)數(shù)組 將會(huì)自動(dòng)忽略此過濾.
20. unique 性驗(yàn)證
'a2'], // a1和a2的需要是的,并且它們都將收到錯(cuò)誤消息 [['a1', 'a2'], 'unique', 'targetAttribute' => ['a1', 'a2']], // a1和a2的需要是的,只有a1將收到錯(cuò)誤消息 ['a1', 'unique', 'targetAttribute' => ['a1', 'a2']], // a1需要通過檢查的兩個(gè)a2和a3的性(使用a1的值)是的 ['a1', 'unique', 'targetAttribute' => ['a2', 'a1' => 'a3']], ] ?>
這驗(yàn)證檢查,如果輸入的值是表列中的。它僅適用于活動(dòng)記錄模型的屬性。它支持驗(yàn)證對(duì)任何單個(gè)列或多個(gè)列。
targetClass: 應(yīng)該是被用于驗(yàn)證查找輸入值的活動(dòng)記錄類的名字。如果沒有設(shè)置,將要使用的類目前正在驗(yàn)證該模型的.
targetAttribute: 應(yīng)該用來驗(yàn)證輸入值的性在targetClass的屬性的名稱。如果沒有設(shè)置,將使用目前正在驗(yàn)證的屬性的名稱。可以使用陣列來驗(yàn)證多列的性的同時(shí)。數(shù)組的值是將被用于驗(yàn)證性的屬性,而數(shù)組鍵是其值要驗(yàn)證的屬性。如果鍵和值都是一樣的,你可以指定的值。
filter: a額外的過濾器被應(yīng)用到用于檢查輸入值的性的數(shù)據(jù)庫查詢。這可以是一個(gè)字符串或代表附加查詢條件的數(shù)組(參考 yii\db\Query::where() 查詢條件的格式), 或者是一個(gè)匿名函數(shù)像: function ($query), 其中$query是你可以在函數(shù)修改查詢對(duì)象。
/tupian/20230522/yii-db-query url 地址驗(yàn)證
'http'], ] ?>
validSchemes: 一個(gè)數(shù)組指定URI方案應(yīng)被認(rèn)為有效。默認(rèn)為['HTTP','HTTPS'],意思是HTTP和HTTPS URL被認(rèn)為是有效的。
defaultScheme: 默認(rèn)URI方案要預(yù)先考慮到輸入,如果它不具有方案的一部分。默認(rèn)為null,意味著不修改輸入值。
enableIDN:驗(yàn)證是否應(yīng)考慮到IDN(國際化域名)。默認(rèn)為false。需要注意的是,為了使用IDN驗(yàn)證您必須安裝并啟用國際PHP擴(kuò)展,否則異常將會(huì)被拋出。
以上是“Yii核心驗(yàn)證器api的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!