public function filters() { return array( 'accessControl', // 實現CRUD操做的訪問控制。 'postOnly + delete', ); } public function accessRules() //這裏就是訪問規則的設置。 { return array( array('allow', // 容許全部用戶執行index,view動做。 'actions'=>array('index','view'), 'users'=>array('*'), ), array('allow', // 只容許通過驗證的用戶執行create, update動做。 'actions'=>array('create','update'), 'users'=>array('@'), // @號指全部註冊的用戶 ), array('allow', // 只容許用戶名是admin的用戶執行admin,delete動做 'actions'=>array('admin','delete'), 'users'=>array('admin'), ), //admin就是指用戶名是admin的用戶,以硬編碼的形式分配用戶權限。 array('deny', // 拒絕全部的訪問。 'users'=>array('*'), ), ); }
1. 建立組件WebUser,它是對CWebUser的擴展。
2. 修改config/main.php文件。 php
3.修改accessRules()。 數據庫
具體細節以下: express
1.WebUser.php 組件代碼: api
<?php // this file must be stored in: // protected/components/WebUser.php class WebUser extends CWebUser { // Store model to not repeat query. private $_model; // Return first name. // access it by Yii::app()->user->first_name function getFirst_Name(){ $user = $this->loadUser(Yii::app()->user->id); return $user->first_name; } // This is a function that checks the field 'role' // in the User model to be equal to 1, that means it's admin // access it by Yii::app()->user->isAdmin() function isAdmin(){ $user = $this->loadUser(Yii::app()->user->id); if ($user==null) return 0; else return $user->role == "管理員"; } // Load user model. protected function loadUser($id=null) { if($this->_model===null) { if($id!==null) $this->_model=User::model()->findByPk($id); } return $this->_model; } } ?>
2.在config/main.php找到以下代碼,添加標紅色的代碼。 cookie
'components'=>array(
'user'=>array(
// enable cookie-based authentication
'allowAutoLogin'=>true,
'class'=>'WebUser',
), app
3.找到須要更改權限的controller類,對accessRules()函數作修改,好比對前文的accessRules()函數作以下修改: yii
public function accessRules() //這裏就是訪問規則的設置。 { return array( array('allow', // 容許全部用戶執行index,view動做。 'actions'=>array('index','view'), 'users'=>array('*'), //*號標識全部用戶包括註冊的、沒註冊的、通常的、管理員級的 ), array('allow', // 只容許通過驗證的用戶執行create, update動做。 'actions'=>array('create','update'), 'users'=>array('@'), // @號指全部註冊的用戶 ), array('allow', // 只容許用戶名是admin的用戶執行admin,delete動做 'actions'=>array('admin','delete'), 'expression'=>'yii::app()->user->isAdmin()', //這樣只有標識爲「管理員」的用戶才能訪問admin,delete動做 ), array('deny', // 拒絕全部的訪問。 'users'=>array('*'), ), );
工做完成! 函數