PHP100 2019-03-27
代码如下:
public function filters() { return array( 'accessControl', // 实现CRUD操作的访问控制。 'postOnly + delete', ); } public function accessRules() //这里就是访问规则的设置。 { return array( array('allow', // 允许所有用户执行index,view动作。 'actions'=>array('index','view'), 'users'=>array('*'), <span></span> ), 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('*'), ), ); }
代码如下:
<strong><?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; } } ?></strong>
代码如下:
'components'=>array( 'user'=>array( // enable cookie-based authentication 'allowAutoLogin'=>true, 'class'=>'WebUser', ),
代码如下:
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('*'), ), );