Home  >  Article  >  php教程  >  [原创]山寨方式实现Yii登录验证

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

WBOY
WBOYOriginal
2016-06-06 20:09:161414browse

这个方法是我自己自创的,没有用到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改一下。

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn