复制代码 代码如下:
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('*'),
),
);
新闻热点
疑难解答