前言
最近在做一个需求时,发现输入正确验证码,但是都提示验证码错误
最后追踪代码发现,如果 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;
}
}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
PbootCMS后台登录验证码不显示或者看不清楚解决办法我们在用pbootcms网站时候,后台验证码不显示或者显示不清楚,这个要怎么解决? 今天html5模板网就给大家列出一下几
Laravel5.2使用Captcha生成验证码实现登录(session巨坑)这篇文章主要介绍了Laravel5.2使用Captcha生成验证码(session巨坑),需要的朋友可以参考下
Yii2中的场景(scenario)和验证规则(rule)详解Yii2的rule用于对模型属性进行验证,scenario用户定义不同场景下需要验证的模型,下面这篇文章主要给大家介绍了关于
MixPHP、Yii和CodeIgniter的并发压力测试小结这篇文章主要给大家介绍了关于MixPHP、Yii和CodeIgniter的并发压力测试的相关资料,文中通过示例代码介绍的非常详细,
phpcms实现验证码替换及phpcms实现全站搜索功能教程详解这篇文章主要介绍了phpcms的验证码替换 及 phpcms实现全站搜索功能,需要的朋友可以参考下
Laravel下生成验证码的类这篇文章主要为大家详细介绍了Laravel下生成验证码的类,具有一定的参考价值,感兴趣的小伙伴们可以参考一下