요청할 때 올바른 인증코드를 입력한 것을 확인했는데, 인증코드가 잘못되었다는 메시지가 떴습니다.
최종 코드 추적 결과 저장 전 모델을 별도로 검증하면 검증이 완료된 후 검증 코드가 다시 생성되는 것으로 나타났습니다. 그런 다음 모델 저장
시 유효성 검증도 수행합니다. 검증 중에 인증 코드가 다시 생성되므로 일치하지 않습니다. Model save
时,也会进行 validate 验证,验证时,验证码已经重新生成了,所以会匹配不上。
问题发现:
我们可以看framework/web/widgets/captcha/CCaptchaAction.php
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; } }
// 如果这里用到了验证码,就会出问题$model = new Test(); $model->validate(); $model->save();
// 这样是正确的$model = new Test(); // 把需要验证的 attribute 放进去,排除验证码字段 $model->validate(array('test1','test2')); $model->save()
위 내용은 yii에서 올바른 인증 코드를 입력하면 오류 메시지가 표시됩니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!