当前位置: 首页 > 编程笔记 >

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

滑令
2023-03-14
本文向大家介绍Yii1.0 不同页面多个验证码的使用实现,包括了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 多验证码内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!

 类似资料:
  • 本文向大家介绍一个实用的php验证码类,包括了一个实用的php验证码类的使用技巧和注意事项,需要的朋友参考一下 万能php验证码类,供大家参考,具体内容如下 code.php是验证码类,类的名称最好和文件名的名称一样,这样有利于我们的查看。 code.php test.php是new一个新的验证码,并把它保存到session中,为我们验证码的验证起到保存和存储的作用。 test.php login

  • 本文向大家介绍js实现同一页面多个不同运动效果的方法,包括了js实现同一页面多个不同运动效果的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js实现同一页面多个不同运动效果的方法。分享给大家供大家参考。具体分析如下: 要点一: 从样式表中根据id和属性名取值。 要点二: 如果设置的是透明度的值,因为有可能会是小数点,所以需要用parseFloat,然后有可能会有小数,用round方法

  • 本文向大家介绍java使用servlet实现验证码,包括了java使用servlet实现验证码的使用技巧和注意事项,需要的朋友参考一下 利用servlet 实现验证码主要继承httpServlet类 下面是web.xml 配置  jsp 文件 简单实用。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍java实用验证码的实现代码,包括了java实用验证码的实现代码的使用技巧和注意事项,需要的朋友参考一下 本文为大家分享了java实用验证码的实现代码,供大家参考,具体内容如下 1、ValidCode      2.XML代码 以上就是本文的全部内容,希望对大家的学习有所帮助。

  • 本文向大家介绍vue实现登录页面的验证码以及验证过程解析(面向新手),包括了vue实现登录页面的验证码以及验证过程解析(面向新手)的使用技巧和注意事项,需要的朋友参考一下 做成之后就 是这个样子 接下来上代码 创建一个组件。显示验证码图片 在登录页面中 验证码输输入框 登录按钮 引入之前的组件(在例子中它叫identify) 在登录组件中引入Identify (这是验证码组件)这一部分略 在dat

  • 本文向大家介绍.Net Core 下使用ZKWeb.System.Drawing实现验证码功能(图形验证码),包括了.Net Core 下使用ZKWeb.System.Drawing实现验证码功能(图形验证码)的使用技巧和注意事项,需要的朋友参考一下 本文介绍.Net Core下用第三方ZKWeb.System.Drawing实现验证码功能。 通过测试的系统: Windows 8.1 64bit