요청할 때 인증번호를 정확하게 입력했는데 인증코드 오류가 떴네요
드디어 코드를 추적해보니 모델이 save
전에는 따로validate
검증을 했고, 검증이 완료되면
인증코드가 다시 생성됩니다. 그러면 save
를 모델링할 때 validate
검증도 수행됩니다. . 인증 과정에서 인증 코드가 다시 생성되어 일치하지 않을 경우
<code>// 如果这里用到了验证码,就会出问题 $model = new Test(); $model->validate(); $model->save(); </code>
<code> // 这样是正确的 $model = new Test(); // 把需要验证的 attribute 放进去,排除验证码字段 $model->validate(array('test1','test2')); $model->save()</code>
framework/web/widgets/captcha/CCaptchaAction.php
를 보면 문제를 쉽게 찾을 수 있습니다
<code> <?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; } } </code>
위의 내용을 포함하여 Yii가 올바른 인증 코드를 입력하지 못한 것에 대한 해결책을 소개합니다. PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.