YII扩展(1)验证码显示和登陆验证IP功能

本文详细介绍了如何在网站登录过程中实现验证码显示及IP地址验证功能。通过修改默认的登录表单模型,在用户连续三次输入错误密码后触发验证码显示,并演示了如何在控制器中集成Yii框架自带的验证码组件。此外,还提供了在登录表单验证中加入IP地址检查的方法,确保只有允许的IP范围内的用户才能成功登录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

验证码显示和登陆验证IP功能:

验证码显示用法:

登陆url是site/login的情况下只需要修改下默认的model类loginForm即可:

在site/login的actionLogin方法里加入

$model->loginCaptchaRequired();

在loginForm类里添加方法:

/**

* 验证码显示判断

*/

public function loginCaptchaRequired()

{

if (Yii::$app->session->get('loginCaptchaRequired') >= 3)

{

$this->setScenario("captchaRequired");

}

}

三次输错密码开启场景captchaRequired

每次输错记入session内:

 

 

前端显示加个if判断场景即可:

 

上图的captcha显示可以在site控制器里behaviors和actions里加入yii自带的验证码方法:

 

上图的captcha显示可以在site控制器里behaviors和actions里加入yii自带的验证码方法:

 

登陆验证IP的用法:

在loginForm的rules里加入

['password', 'validateIp'],

加入方法:

 /**
     * 验证ip地址是否正确
     *
     * @param $attribute
     * @throws \yii\base\InvalidConfigException
     */
    public function validateIp($attribute)
    {
        $ip = Yii::$app->request->userIP;
        $allowIp = '192.168.33.1,192.168.33.2';  //也可以写入配置里
        if (!empty($allowIp))
        {
            $ipList = explode(",", $allowIp);
            if (!in_array($ip, $ipList))
            {
                // 记录行为日志
//                Yii::$app->services->sys->log('login', '限制IP登录', false);
                $this->addError($attribute, '登录失败');
            }
        }
    }

IP不符合时显示如图所示:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值