前言
最近在做一个需求时,发现输入正确验证码,但是都提示验证码错误
最后追踪代码发现,如果 Model 在 save 前,单独做了 validate 验证,则在验证结束后,会重新生成验证码
然后在我们 Model save
时,也会进行 validate 验证,验证时,验证码已经重新生成了,所以会匹配不上
1
2
3
4
5
6
7
|
// 如果这里用到了验证码,就会出问题 $model = new Test(); $model ->validate(); $model ->save(); |
1
2
3
4
5
6
7
|
// 这样是正确的 $model = new Test(); // 把需要验证的 attribute 放进去,排除验证码字段 $model ->validate( array ( 'test1' , 'test2' )); $model ->save() |
我们可以看framework/web/widgets/captcha/CCaptchaAction.php
可以很容易就发现问题了
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
<?php class CaptchaAction extends CCaptchaAction { public function validate( $input , $caseSensitive ) { $code = $this ->getVerifyCode(); $valid = $caseSensitive ? ( $input === $code ) : ! strcasecmp ( $input , $code ); $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 ; } } |
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://www.phpyc.com/jie-jue-yii-shu-ru-zheng-que-yan-zheng-ma-yan-zheng-shi-bai/