当前位置:  首页  >  PHP教程  >  PHP 基础  >  开发经验

[原创]山寨方式实现Yii登录验证

这个方法是我自己自创的,没有用到yii的filter验证机制,但最终也实现了,而且自我感觉非常良好,有强迫症的同学就算了,哈哈。进入正题,大家都知道创建app的时候会在protectedcomponent下自动创建一个Controller.php,这个Controller继承自CController,

这个方法是我自己自创的,没有用到yii的filter验证机制,但最终也实现了,而且自我感觉非常良好,有强迫症的同学就算了,哈哈。 进入正题,大家都知道创建app的时候会在protected/component下自动创建一个Controller.php,这个Controller继承自CController,

这个方法是我自己自创的,没有用到yii的filter验证机制,但最终也实现了,而且自我感觉非常良好,有强迫症的同学就算了,哈哈。
进入正题,大家都知道创建app的时候会在protected/component下自动创建一个Controller.php,这个Controller继承自CController,而用Gii在创建自己项目中需要的controller的时候默认继承这个Controller.php中的Controoler,这样咱们就直接从这个controller中下手。
重载beforeAction函数,代码如下:

protected function beforeAction($action){
	if (Yii::app()->user->isGuest) {
		if(get_class($action->getController()) != 'SiteController' || strtolower($action->getId())  != 'login'){
			Yii::app()->user->loginRequired() ;
		}
	}
	return parent::beforeAction($action);
}

看完代码大家应该大体明白是什么意思了,对,就是先判断当前用户是否为访客(未登录的),然后判断当前action的controller是否请求自SiteController,如果是,再判断是否请求的SiteController中的login动作,如果不是的话重定向至登录页面。经测试完全没问题,如果有特殊需求,比如过滤多个controller和多个action,可以写一个数组,再进行一下遍历处理就可以了。
另外可能你的登录页面并不是yii创建的时候默认的,这样的话建议就重载一下CWebUser,把CWebUser中的loginUrl改一下。

吐了个 "CAO" !
扫码关注 PHP1 官方微信号
PHP1.CN | 中国最专业的PHP中文社区 | PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | PHP问答
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved PHP1.CN 第一PHP社区 版权所有