前言
最近在做一個需求時,發(fā)現(xiàn)輸入正確驗證碼,但是都提示驗證碼錯誤
最后追蹤代碼發(fā)現(xiàn),如果 Model 在 save 前,單獨(dú)做了 validate 驗證,則在驗證結(jié)束后,會重新生成驗證碼
然后在我們 Model save
時,也會進(jìn)行 validate 驗證,驗證時,驗證碼已經(jīng)重新生成了,所以會匹配不上
// 如果這里用到了驗證碼,就會出問題 $model = new Test(); $model->validate(); $model->save();
// 這樣是正確的 $model = new Test(); // 把需要驗證的 attribute 放進(jìn)去,排除驗證碼字段 $model->validate(array('test1','test2')); $model->save()
我們可以看framework/web/widgets/captcha/CCaptchaAction.php
可以很容易就發(fā)現(xiàn)問題了
<?php class CaptchaAction extends CCaptchaAction { public function validate($input, $caseSensitive) { $code = $this->getVerifyCode(); $valid = $caseSensitive ? ($input === $code) : !strcasecmp($input, $code); $session = Yii::app()->session; $session->open(); $name = $this->getSessionKey() . 'count'; if (!Yii::app()->request->isAjaxRequest) { $session[$name] = $session[$name] + 1; } // 這里會重新生成 if ($session[$name] > $this->testLimit && $this->testLimit > 0) { $this->getVerifyCode(true); } return $valid; } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對的支持。
【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。