zoukankan      html  css  js  c++  java
  • YII2中验证码的使用

    验证码的使用是比较频繁的。YII2中已经帮我们做好了封装。

    首先我们在控制器里创建一个actions方法,用于使用yiicaptchaCaptchaAction

    <?php
    
    namespace appcontrollers;
    
    use YII;
    use yiiwebController;
    
    class IndexController extends Controller
    {
        public function actionIndex()
        {
            if (YII::$app->request->isPost) {
                //获取post过来的验证码
                $verify = YII::$app->request->post('verify');
    
                //我们手动进行验证,第二个参数表示是否区分大小写
                if ($this->createAction('captcha')->validate($verify, false)) {
                    echo '成功';
                } else {
                    echo '失败';
                }
    
            } else {
                return $this->renderPartial('index');
            }
        }
    
        //actions的作用主要是共用功能相同的方法
        //当用户访问index/captcha时,actions就会调用yiicaptchaCaptchaAction方法
        public function actions()
        {
            return [
                'captcha' => [
                    'class' => 'yiicaptchaCaptchaAction',
                    'fixedVerifyCode' => null,
                    //背景颜色
                    'backColor' => 0x000000,
                    //最大显示个数
                    'maxLength' => 4,
                    //最少显示个数
                    'minLength' => 4,
                    //间距
                    'padding' => 2,
                    //高度
                    'height' => 30,
                    //宽度
                    'width' => 85,
                    //字体颜色
                    'foreColor' => 0xffffff,
                    //设置字符偏移量
                    'offset' => 4,
                ],
            ];
        }
    }
    

    显示页面代码如下:

    <?php
    use yiihelpersUrl;
    use yiihelpersHtml;
    ?>
    <!doctype html>
    <html lang="zh-CN">
    <head>
        <meta charset="UTF-8">
        <title>分页显示</title>
    </head>
    <body>
        <form action="<?php echo Url::toRoute('index/index'); ?>" method="post">
            验证码:<input type="text" name="verify"><br>
            <img id="verifyImg" src="<?php echo Url::toRoute('index/captcha'); ?>"><br>
            <input type="submit" value="提交">
            <input name="_csrf" type="hidden" value="<?php echo Yii::$app->request->csrfToken; ?>">
        </form>
    
        <?php echo Html::jsFile('@web/js/jquery-3.3.1.min.js'); ?>
        <script type="text/javascript">
            $(function () {
                //处理点击刷新验证码
                $("#verifyImg").on("click", function () {
                    $.get("<?php echo Url::toRoute('index/captcha') ?>?refresh", function (data) {
                        $("#verifyImg").attr("src", data["url"]);
                    }, "json");
                });
            });
        </script>
    </body>
    </html>
    

    演示结果如下:

    上面控制器中验证码的验证方式是我们手动的。我们也可以创建一个模型配置rules()来自动完成。

    <?php
    
    namespace appmodels;
    
    use yiiaseModel;
    
    class VerifyForm extends Model
    {
    
        //变量名为你表单中输入验证码控件的name
        public $verify;
    
        public function rules()
        {
            return [
                ['verify', 'required', 'message' => '请填写验证码'],
                //注意captchaAction的设置,指向你显示验证码的action,这里我们的是index/captcha
                ['verify', 'captcha', 'captchaAction' => 'index/captcha', 'caseSensitive' => false, 'message' => '验证码错误'],
            ];
        }
    }
    

    控制器代码修改如下:

    <?php
    
    namespace appcontrollers;
    
    use YII;
    use appmodelsVerifyForm;
    use yiiwebController;
    
    class IndexController extends Controller
    {
        public function actionIndex()
        {
            if (YII::$app->request->isPost) {
                $verify = new VerifyForm();
                $verify->load(YII::$app->request->post(), '');
    
                //自动验证
                if ($verify->validate()) {
                    echo '成功';
                } else {
                    var_dump($verify->errors);
                }
    
            } else {
                return $this->renderPartial('index');
            }
        }
    
        //actions的作用主要是共用功能相同的方法
        //当用户访问index/captcha时,actions就会调用yiicaptchaCaptchaAction方法
        public function actions()
        {
            return [
                'captcha' => [
                    'class' => 'yiicaptchaCaptchaAction',
                    'fixedVerifyCode' => null,
                    //背景颜色
                    'backColor' => 0x000000,
                    //最大显示个数
                    'maxLength' => 4,
                    //最少显示个数
                    'minLength' => 4,
                    //间距
                    'padding' => 2,
                    //高度
                    'height' => 30,
                    //宽度
                    'width' => 85,
                    //字体颜色
                    'foreColor' => 0xffffff,
                    //设置字符偏移量
                    'offset' => 4,
                ],
            ];
        }
    }
    

      

  • 相关阅读:
    常见的MYSQL高可用解决方案
    CDN——到底用还是不用?
    Maven学习总结
    Git – Fast Forward 和 no fast foward
    Spring boot 打成jar包问题总结
    Spring Data JPA进阶——Specifications和Querydsl
    Arp攻击实战
    crontab命令
    mtr命令
    如何使用qperf来衡量网络带宽和延迟性能?
  • 原文地址:https://www.cnblogs.com/jkko123/p/8669568.html
Copyright © 2011-2022 走看看