yii权限控制的方法(三种方法)

网络编程 2021-07-05 09:09www.168986.cn编程入门
这篇文章主要介绍了yii权限控制的方法,结合实例形式分析了通过aessControl,插件机混合模式三种方法实现权限控制的实现技巧,需要的朋友可以参考下

本文实例讲述了yii权限控制的方法。分享给大家供大家参考,具体如下:

这里摘录以下3种:

1. 通过aessControl:

public function filters()
{
  return array(
    'aessControl', // perform aess control for CRUD operations
  );
}
/**
 * Specifies the aess control rules.
 * This method is used by the 'aessControl' filter.
 * @return array aess control rules
 */
public function aessRules()
{
  return array(
    array('allow', // allow authenticated users to aess all actions
      'users'=>array('@'),
    ),
    array('deny', // deny all users
      'users'=>array('*'),
    ),
  );
}

2. 通过插件(如:right)

public function filters()
{
  return array(
    'rights',
  );
}

3. 混合模式:

/**
 * @return array action filters
 */
public function filters()
{
  return array(
    'updateOwn + update', // Apply this filter only for the update action.
    'rights',
  );
}
/**
 * Filter method for checking whether the currently logged in user
 * is the author of the post being aessed.
 */
public function filterUpdateOwn($filterChain)
{
  $post=$this->loadModel();
  // Remove the 'rights' filter if the user is updating an own post
  // and has the permission to do so.
  if(Yii::app()->user->checkAess('PostUpdateOwn', array('userid'=>$post->author_id)))
    $filterChain->removeAt(1);
  $filterChain->run();
}

如果有权限的基础上,开放某些动作的权限,可以通过allowedActions:

public function allowedActions()
{
  return 'aulate,aulate2';
}

希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by