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

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

WBOY
WBOYasal
2016-06-06 20:09:161454semak imbas

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

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:thinkphp的if标签Artikel seterusnya:PHP Hex Oct 在线解密与进制转换