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

 更新时间:2020年03月06日 12:43:10   作者:如若时光萧瑟去丶  
这篇文章主要介绍了Yii1.0 不同页面多个验证码的使用实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

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

HTML代码

<!DOCTYPE html>
<html>
<head>
  <title>业务A的验证码页面</title>
</head>
<body>
  <img src="" alt="验证码" id="imgValCode">
</body>
</html>
 <script src="jquery.js"></script>
  <script type="text/javascript">
  $.ajax({
    url: '/Captcha/A/refresh', //不同业务模块调用不同的url B业务调用/Captcha/B/refresh
    type: 'get',
    dataType: 'json',
    async: true,
    success:function(data) {
      if ( data.src ) {
        $('#imgValCode').attr('src',data.src);
      }
    }
  });
</script>

PHP代码

<?php
/**
 * yii1.0 验证码类
 * 多个验证码,方式业务A页面和业务B页面同时打开,共用一个验证码session,导致其中一个被失效的问题
 */
class CaptchaController extends CHttpModuleController 
{
  /**
   * 验证码生成函数
   */
  public function actions() 
  {
    return [
      //A业务验证码
      'A' => [
        '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 多验证码内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • phpstudy2018升级MySQL5.5为5.7教程(图文)

    phpstudy2018升级MySQL5.5为5.7教程(图文)

    这篇文章主要介绍了phpstudy2018升级MySQL5.5为5.7教程(图文),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • PHP利用imagick生成组合缩略图

    PHP利用imagick生成组合缩略图

    这里说的imagick 是 ImageMagick 在PHP下的扩展,本文给大家介绍PHP利用imagick生成组合缩略图,需要的朋友参考下
    2016-02-02
  • PHP实现单条sql执行多个数据的insert语句方法

    PHP实现单条sql执行多个数据的insert语句方法

    今天小编就为大家分享一篇PHP实现单条sql执行多个数据的insert语句方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • php上传文件问题汇总

    php上传文件问题汇总

    这篇文章主要给大家汇总介绍了一些php上传文件问题,需要的朋友可以参考下
    2015-01-01
  • php中的登陆login实例代码

    php中的登陆login实例代码

    这篇文章主要为大家详细介绍了php中的登陆login实例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • PHP CURL 内存泄露问题解决方法

    PHP CURL 内存泄露问题解决方法

    这篇文章主要介绍了PHP CURL 内存泄露问题解决方法,CRUL长时间访问HTTPS网站时有内存泄露问题,本文经过反复调试找到了解决方法,需要的朋友可以参考下
    2015-02-02
  • PHP is_array() 检测变量是否是数组的实现方法

    PHP is_array() 检测变量是否是数组的实现方法

    下面小编就为大家带来一篇PHP is_array() 检测变量是否是数组的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考,一起跟随小编过来看看吧
    2016-06-06
  • PHP的bz2压缩扩展工具详解

    PHP的bz2压缩扩展工具详解

    今天,我们先学习一个比较简单但不太常用的压缩格式:Bzip2,对PHP的bz2压缩扩展工具相关知识感兴趣的朋友跟随小编一起学习吧
    2021-05-05
  • 基于Laravel5.4实现多字段登录功能方法示例

    基于Laravel5.4实现多字段登录功能方法示例

    最近在工作中遇到一个需求,需要实现多字段登录的一个效果,就是可以使用手机或者邮箱任一种方式的登录,现在将解决的过程分享出来,所以这篇文章主要给大家介绍了基于Laravel5.4实现多字段登录功能的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-08-08
  • PHP实现简单的计算器

    PHP实现简单的计算器

    这篇文章主要为大家详细介绍了PHP实现简单的计算器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08

最新评论