開發(fā)Web應(yīng)用有一個很重要的原則,就是不要相信任何輸入的數(shù)據(jù),在使用之前必須要進(jìn)行有效性檢查,否則很有可能會引發(fā)各種安全性問題。Yii 2當(dāng)然也不會忽略這個問題,提供了校驗器這一有力的工具,該工具可同時提供客戶端和服務(wù)器端的數(shù)據(jù)校驗。
創(chuàng)新互聯(lián)公司長期為近1000家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為盧龍企業(yè)提供專業(yè)的網(wǎng)站制作、成都網(wǎng)站建設(shè),盧龍網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。在Model內(nèi),重載rules()接口,配置每個字段的規(guī)則,如下(以LoginForm為例):
public functionrules() |
每一行中,前面是字段名稱,最后一個元素是規(guī)則的名稱。這些規(guī)則最終是通過“校驗器”來完成校驗的。當(dāng)然內(nèi)置的校驗器肯定不能夠全部滿足需求,因此Yii 2在根據(jù)規(guī)則名稱創(chuàng)建校驗器的時候,會首先檢查該Model中是否有跟規(guī)則名稱相同的函數(shù),如果有,則校驗規(guī)則的時候就直接用該函數(shù)來完成校驗,譬如上面代碼中的“validatePassword”規(guī)則,在LoginForm中就有接口:
public functionvalidatePassword($attribute, $params) |
Yii 2中,校驗器存放于vendor\yiisoft\yii2\validators目錄下,有如下內(nèi)置校驗器(這些校驗器沒有全部都用過,這里列出來功能,細(xì)節(jié)待用到的時候再研究):
boolean | 檢測輸入值是否為boolean類型 |
captcha | 檢測輸入的校驗碼是否正確,這個需要與yii\captcha\CaptchaAction一起使用 |
compare | 與指定值進(jìn)行比較,確認(rèn)兩者是否符合比較條件(如:>=、=、<=),譬如注冊時會要求輸入兩次密碼,要比較這兩次輸入的密碼是否相同 |
date | 檢測輸入值是否為date類型 |
datetime | 檢測輸入值是否為datetime類型 |
time | 檢測輸入值是否為time類型 |
default | 這個實際上不是一個校驗器,是當(dāng)某個屬性為空時,提供默認(rèn)值用的 |
double | 檢測輸入值是否為double類型 |
each | 對輸入的一組數(shù)據(jù)進(jìn)行校驗 |
檢測輸入值是否為email地址 | |
exist | 判斷輸入的值是否在數(shù)據(jù)庫中存在,常用于檢查某個值在外鍵中是否存在 |
file | 檢測輸入值是否為文件 |
filter | 將輸入值轉(zhuǎn)換為另一個值,它實際上不是個校驗器。 |
p_w_picpath | 檢測輸入值是否為圖片 |
in | 檢測輸入值是否在指定的列表中 |
integer | 檢測輸入值是否為integer類型 |
match | 使用正則表達(dá)式檢查輸入值 |
required | 檢測輸入值是否為空 |
safe | 標(biāo)志輸入的字段是否可信,Yii對Model的每個字段都要求必須要有校驗器,但是有時候有些字段的確不需要,譬如主鍵ID。 |
string | 檢測輸入值是否為string類型 |
trim | 這實際上是一個轉(zhuǎn)換器,去除掉輸入的前后空格 |
unique | 檢測輸入值在表中是否唯一 |
url | 檢測輸入值是否為URL |
ip | 檢測輸入值是否為IP地址 |
參考文獻(xiàn):
1、http://www.cnblogs.com/yhdsir/p/5181938.html
新建一個文件:
?php
namespace common\helps;
use yii\validators\Validator;
class ArrayValidator extends Validator
{
publicfunction validateAttribute($model, $attribute)
{
if (!is_array($model->$attribute)) {
$this->addError($model, $attribute, $attribute . '必須是一個數(shù)組');
}
}
}
使用的時候:
publicfunction rules()
{
return [
...
['kind_ids','common\helps\ArrayValidator'], // 自定義驗證
...
];
}
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務(wù)器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機(jī)房獨(dú)有T級流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確進(jìn)行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務(wù)器買多久送多久。
標(biāo)題名稱:Yii2——字段校驗-創(chuàng)新互聯(lián)
網(wǎng)站URL:http://www.rwnh.cn/article10/cecido.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)、移動網(wǎng)站建設(shè)、軟件開發(fā)、網(wǎng)站收錄、品牌網(wǎng)站制作、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容