Yii1.0 不同页面多个验证码的使用实现

当业务A页面有验证码,且业务B页面也需要验证码。这个时候,如果A和B共用一个验证码,则会出现这种情况:
A页面出现验证码,这个时候打开B页面验证码,再回到A页面输入验证码,即使验证码输入无误,也会验证不通过。因为A和B共用一个验证码,也就是验证码存储的session是一个,这样对用户体验很不好。
解决方法如下:

HTML代码




  业务A的验证码页面


  验证码


 
  

PHP代码

 [
        'class' => 'application.components.MyCaptcha.MyCaptchaAction',
        'backColor' => 0xFFFFFF,
        'minLength' => 5,
        'maxLength' => 5,
        'offset' => 5,
        'testLimit' => 1,
        'width' => 100,
        'height' => 40,
        'isInterferingLine' => true, //是否启用干扰线
        'interferingLineNumber' => 8, //干扰线数量设置
        'foreColor' => '0x0c0c0e'
      ],
      //B业务验证码
      'B' => [
        'class' => 'application.components.MyCaptcha.MyCaptchaAction',
        'backColor' => 0xFFFFFF,
        'minLength' => 5,
        'maxLength' => 5,
        'offset' => 5,
        'testLimit' => 1,
        'width' => 100,
        'height' => 40,
        'isInterferingLine' => false, //是否启用干扰线
        'interferingLineNumber' => 8, //干扰线数量设置
        'foreColor' => '0x0c0c0e'
      ]
    ];
  }

  /**
   * 验证码验证函数
   * 在需要验证验证码的控制器中调用,传递businessId(业务类型id)作为区分不同验证码的id
   * 调用方式:
   * Yii::app()->runController('Captcha/actionVerifyCode',[ 'businessId' => 'A' ]);
   */
  public function actionVerifyCode($businessId) 
  {
    $code = Yii::app()->request->getPost('code');        //接收用户输入的验证码
    if ( $businessId == 'A' ) {
      $vcode = $this->createAction('A')->getVerifyCode();   //获取A业务的验证码
    } else if ( $businessId == 'B' ) {
      $vcode = $this->createAction('B')->getVerifyCode();   //获取B业务的验证码
    }
    if ( empty($vcode) || empty($code) || $vcode != $code ) {  //验证用户输入验证码与验证码是否相等
      return false;    //验证不通过
    }
    return true;  //验证通过
  }
}
?>

到此这篇关于Yii1.0 不同页面多个验证码的使用实现的文章就介绍到这了,更多相关Yii1.0 多验证码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(Yii1.0 不同页面多个验证码的使用实现)