前言
最近在做一個需求時,發現輸入正確驗證碼,但是都提示驗證碼錯誤
最后追蹤代碼發現,如果 Model 在 save 前,單獨做了 validate 驗證,則在驗證結束后,會重新生成驗證碼
然后在我們 Model save
時,也會進行 validate 驗證,驗證時,驗證碼已經重新生成了,所以會匹配不上
// 如果這里用到了驗證碼,就會出問題 $model = new Test(); $model->validate(); $model->save();
// 這樣是正確的 $model = new Test(); // 把需要驗證的 attribute 放進去,排除驗證碼字段 $model->validate(array('test1','test2')); $model->save()
我們可以看framework/web/widgets/captcha/CCaptchaAction.php
可以很容易就發現問題了
<?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; } }
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對的支持。
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。