YII开发技巧分享——控制器中动作权限控制

7 篇文章 0 订阅
在YII开发中,我们可以通过控制器中对accessRules函数的配置进行相应动作权限控制,默认情况下可能是这样:
public function accessRules()
    {
        ……
            array('allow',
                'actions'=>array('admin','delete'),
                'users'=>array('admin'),
            ),
            array('deny', 
                'users'=>array('*'),
            ),
        );
    }
       在函数中可以配置具体哪些用户可以访问某些动作,但是在开发过程中我们很容易会发现上面有的几个方式完全不够用,于是不约而同地就会相对这个能不能访问的规则是否能让我们自定义了,答案是肯定的,确实可以自定义!
       具体方法是这样的(主要是用到accessRules中的expression属性):
       在accessRules函数体中:
return array(
            array('allow',
                'actions'=>array('admin'),
                'expression'=>array($this,'getadvancedusers'),
            ),
            ……
        );
       没错就是这一句“ 'expression'=>array($this,'advancedusers')”,我想相信接下来大家就很清楚了,就是在这个控制器中添加一个advancedusers函数(该函数名自己可以根据自己的需要修改),函数如下:
    public function advancedusers()
    {
        $users=Users::model()->findByAttributes(array('uid'=>Yii::app()->user->id));

        return ($users->ugid == 1);//看当前用户的用户组ID是否为1(我这里1代表高级用户)


  1. public function accessRules()  
  2. {  
  3.     return array(  
  4.         array('allow',  // 所有用户有操作权限:index,view  
  5.             'actions'=>array('index','view'),  
  6.             'users'=>array('*'),  
  7.         ),  
  8.         array('allow', // 仅登录用户有权限操作:create,update  
  9.             'actions'=>array('create','update'),  
  10.             'users'=>array('@'),  
  11.         ),  
  12.         array('allow', // 指定用户有权限操作:admin,delete  
  13.             'actions'=>array('admin','delete'),  
  14.             'users'=>array('admin'),  
  15.         ),  
  16.         array('deny',  // 禁止所有用户操作  
  17.             'users'=>array('*'),  
  18.         ),  
  19.     );  


    }
       这里返回一个bool值,返回0代表检查不通过,就是说没有访问admin这个动作的权限!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值