首頁 >php教程 >php手册 >[原创]山寨方式实现Yii登录验证

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

WBOY
WBOY原創
2016-06-06 20:09:161453瀏覽

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

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn