深入解析yii权限分级式访问控制的实现(非RBAC法)_php技巧
yii framework 提供了2套权限访问系统,一套是简单的filter(过滤器)模式,另一套是复杂全面的RBAC模式,我这里要讲的是第一套(因为我也刚刚学到这里)。如 果你有研究过YII官方的demo blog,一定知道,比如,由gii自动生成的user模块,自动附带了简单的filter权限分配功能,具体细节请参照blog手册的“用户验证”一章 节,以及yii官方指南的“验证和授权”一章节。(注意,我这里所指的模块,只是我个人对与user有关的文件的统称,与yii文件系统的模块 (module)含义不同。)
关于权限分配的文件大多在controllers里,比如打开UserController.php文件你会看到2个类函数。
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('*'),
),
);
}
关于更多的访问规则的设定请参照官方文件http://www.yiiframework.com/doc/api/1.1/CAccessControlFilter
好了,现在要开始按照我们自己的需求设置适合自己的权限分配了。我们希望filter访问控制模式能更完美一点,按照常识,我们希望它能按照数据库里user表里不同级别用户,实行不同的授权,而不是用硬编码的形式控制。
回到demo blog,我先对数据库的tbl_user表做修改,在原来的基础上加上role一项。对原来的用户信息记录添加role的value为"管理员"或"一般用户"。
然后依次执行以下3个步骤:
1. 创建组件WebUser,它是对CWebUser的扩展。
2. 修改config/main.php文件。
3.修改accessRules()。
具体细节如下:
1.WebUser.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找到如下代码,添加标红色的代码。
'components'=>array(
'user'=>array(
// enable cookie-based authentication
'allowAutoLogin'=>true,
'class'=>'WebUser',
),
3.找到需要更改权限的controller类,对accessRules()函数做修改,比如对前文的accessRules()函数做如下修改:
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('*'),
),
);
工作完成!

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











権限管理とアクセス制御に Vue を使用する方法 最新の Web アプリケーションでは、権限管理とアクセス制御は重要な機能です。人気のある JavaScript フレームワークとして、Vue は権限管理とアクセス制御を実装するためのシンプルかつ柔軟な方法を提供します。この記事では、Vue を使用して基本的な権限管理とアクセス制御機能を実装する方法を紹介し、コード例を添付します。ロールと権限の定義 開始する前に、まずアプリケーションでロールと権限を定義する必要があります。ロールは特定の権限のセットであり、

クラウド コンピューティング テクノロジの継続的な発展により、データのバックアップはすべての企業が行う必要のあるものになりました。この文脈では、可用性の高いクラウド バックアップ システムを開発することが特に重要です。 PHP フレームワーク Yii は、開発者が高性能の Web アプリケーションを迅速に構築できる強力なフレームワークです。ここでは、Yii フレームワークを使用して可用性の高いクラウド バックアップ システムを開発する方法を紹介します。データベースモデルの設計 Yii フレームワークでは、データベースモデルは非常に重要な部分です。データ バックアップ システムには多くのテーブルとリレーションシップが必要なため、

Nginx がリクエスト ソース IP に基づいてアクセス コントロール構成を実装する方法には、特定のコード サンプルが必要です。ネットワーク アプリケーション開発において、サーバーを悪意のある攻撃から保護することは非常に重要なステップです。 Nginx をリバース プロキシ サーバーとして使用すると、IP アクセス制御を構成して特定の IP アドレスへのアクセスを制限し、サーバーのセキュリティを向上させることができます。この記事では、Nginx でリクエスト元 IP に基づいたアクセス制御構成を実装する方法と、具体的なコード例を紹介します。まず、Nginx 構成ファイルを編集する必要があります

win10 でアクセス制御エディターを開けないという問題はまれです。この問題は通常、外付けハード ドライブや USB フラッシュ ドライブで発生します。実際、解決策は非常に簡単です。セーフ モードで開いて確認するだけです。見てみましょう。詳細は以下をご覧ください。 Win10 でアクセス コントロール エディターを開くことができません 1. ログイン インターフェイスで、Shift キーを押しながらボタンをクリックし、2 をクリックします。--、3 をクリックします。再起動後、F5 キーを押して入力して、入力できるかどうかを確認します。 win10 セーフモード関連記事>>>win10 セーフモードの入り方<<<>>>win10 セーフモードでシステムを修復する方法<<<

インターネットの発展に伴い、アクセス制御の問題はますます重要なテーマになってきています。従来の権限管理では、一般に、リソースを制御するためにロール権限リストまたはアクセス制御リストが使用されます。ただし、この方法は、さまざまな役割やリソースに対するアクセス制御を柔軟に実装することが難しいため、大規模なアクセス制御のニーズに適応できないことがよくあります。この問題を解決するには、Go 言語を使用して大規模なアクセス制御問題を解決することが有効な方法となっています。 Go 言語は同時プログラミング用の言語であり、優れた同時実行パフォーマンスと高速なコンパイルを備えています。

Nginx のトラフィック分析とアクセス制御方法についての詳細な説明 Nginx は、高性能のオープンソース Web サーバーであり、強力でスケーラブルであるため、インターネット分野で広く使用されています。実際のアプリケーションでは、通常、Nginx トラフィックを分析してアクセスを制御する必要があります。この記事では、Nginx のトラフィック分析とアクセス制御方法を詳しく説明し、対応するコード例を提供します。 1. Nginx トラフィック分析 Nginx には、トラフィック分析に使用できる組み込み変数が多数用意されています。その中でもよく使われるのが、

インターネット アプリケーションの普及に伴い、機密データが悪用されたり盗まれたりしないように、アプリケーション内のデータを保護したいと考えています。解決策の 1 つは、ロールベースのアクセス制御 (RBAC) を使用することです。ロールベースのアクセス制御 (RBAC) は、ユーザーとロール間の関係に基づくアクセス制御モデルです。このモデルの中心的な考え方は、アクセス制御操作をユーザーに直接リンクするのではなく、ユーザーの役割をアクセス制御操作にリンクすることです。このアプローチにより、アクセス制御の柔軟性が向上します。

Web アプリケーションの需要が高まるにつれ、開発者が開発フレームワークを選択する選択肢はますます増えています。 PHP フレームワークとして人気のある Symfony と Yii2 は、どちらも強力な機能とパフォーマンスを備えていますが、大規模な Web アプリケーションを開発する必要がある場合、どちらのフレームワークがより適しているのでしょうか。次に、より良い選択を行うために、Symphony と Yii2 の比較分析を行います。基本概要 Symphony は、PHP で書かれたオープンソースの Web アプリケーション フレームワークであり、上に構築されています。
