ホームページ > php教程 > php手册 > [原创]山寨方式实现Yii登录验证

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

WBOY
リリース: 2016-06-06 20:09:16
オリジナル
1462 人が閲覧しました

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

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート