zoukankan      html  css  js  c++  java
  • Yii2自带验证码实现

      总共分为三个方面:控制器配置、模型rules配置和视图配置。

           第一步:控制器配置

        将下列代码配置在actions中,请求验证码链接对应为 “控制器/captcha”

               'captcha' => [
                        'class' => 'yiicaptchaCaptchaAction',
                   //     'backColor'=>0x000000,//背景颜色
                        'maxLength' => 4, //最大显示个数
                        'minLength' => 4,//最少显示个数
                        'padding' => 5,//间距
                        'height'=>45,//高度
                        'width' => 75,  //宽度
                     //   'foreColor'=>0xffffff,     //字体颜色
                        'offset'=>4,
                ],
    

      

           第二步:模型rules配置,即验证配置。

        首先声明公共变量 

            public $verifyCode
    

             其次在rules方法中配置验证

    ['verifyCode', 'captcha','captchaAction'=>'user/captcha','on' => ['login']]

        在这条配置中的"captchaAction"加入了配置,即控制器的路由,如果不进行配置的话会走site/captcha的路由,这是框架样例的路由。

           第三步:视图中的配置

        在ActiveForm中加入如下代码即可了

          

    <?= $form->field($model,'verifyCode')->widget(
                        Captcha::className(),
                        [
                            'template' => '{image}{input}',
                            'captchaAction'=>'user/captcha', // 此注意要使用自己配置的那个控制器验证码路由
                            'imageOptions'=>[ 'style'=>'cursor:pointer;77px']
                        ]
                    )
    

      最后有一个巨坑的问题:由于编码过程中使用了一些windows下的换行符或者空格,导致了未知的输出,会导致验证码图片不能够正常的生成。

        这是需要在CaptchaAction类中的renderImageByGD方法中加入如下代码:

            imagecolordeallocate($image, $foreColor);
    
            ob_clean(); // 此行为插入代码,目的是清空缓存区为输出图片提供干净空间。
            ob_start();
            imagepng($image);
            imagedestroy($image);
    

      

  • 相关阅读:
    Android在代码中获取应用签名
    Android之密码的显示与隐藏
    如何把本地项目上传到Github
    Android之移动热修复
    Android之apk优化
    Android之内存泄漏
    Java类加载顺序
    mysql系列-⼀条SQL查询语句是如何执⾏的?
    java操作redis(jedis)常用方法示例
    mybatis拦截器实现通用权限字段添加
  • 原文地址:https://www.cnblogs.com/youligai/p/7478448.html
Copyright © 2011-2022 走看看