ホームページ php教程 php手册 深入解析yii权限分级式访问控制的实现(非RBAC法)

深入解析yii权限分级式访问控制的实现(非RBAC法)

Jun 06, 2016 pm 08:31 PM
yii アクセス制御

本篇文章是对yii权限分级式访问控制的实现方法进行了详细的分析介绍,需要的朋友参考下

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('*'),
),
);
}


关于更多的访问规则的设定请参照官方文件
好了,现在要开始按照我们自己的需求设置适合自己的权限分配了。我们希望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('*'),
),
);


工作完成!
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Vue を使用して権限管理とアクセス制御を行う方法 Vue を使用して権限管理とアクセス制御を行う方法 Aug 02, 2023 pm 09:01 PM

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

Go 言語を使用して大規模なアクセス制御問題を解決する Go 言語を使用して大規模なアクセス制御問題を解決する Jun 15, 2023 pm 02:59 PM

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

Nginx がリクエストソース IP に基づいてアクセス制御構成を実装する方法 Nginx がリクエストソース IP に基づいてアクセス制御構成を実装する方法 Nov 08, 2023 am 10:09 AM

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

Win10 でアクセス コントロール エディターを開けない Win10 でアクセス コントロール エディターを開けない Jan 03, 2024 pm 10:05 PM

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

Nginx のトラフィック分析とアクセス制御方法の詳細な調査 Nginx のトラフィック分析とアクセス制御方法の詳細な調査 Aug 05, 2023 pm 05:46 PM

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

Symfony と Yii2: 大規模な Web アプリケーションの開発にはどちらのフレームワークが適していますか? Symfony と Yii2: 大規模な Web アプリケーションの開発にはどちらのフレームワークが適していますか? Jun 19, 2023 am 10:57 AM

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

PHP フレームワーク Yii を使用して可用性の高いクラウド バックアップ システムを開発する方法 PHP フレームワーク Yii を使用して可用性の高いクラウド バックアップ システムを開発する方法 Jun 27, 2023 am 09:04 AM

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

PHP はクロスドメインリクエストとアクセス制御をどのように処理しますか? PHP はクロスドメインリクエストとアクセス制御をどのように処理しますか? Jun 30, 2023 pm 11:04 PM

PHP はクロスドメインリクエストとアクセス制御をどのように処理しますか?要約: インターネット アプリケーションの開発に伴い、クロスドメイン リクエストとアクセス制御が PHP 開発における重要な問題になっています。この記事では、開発者がこれらの問題をよりよく理解し、対処できるようにすることを目的として、PHP がクロスドメイン要求とアクセス制御を処理する方法とテクニックを紹介します。クロスドメインリクエストとは何ですか?クロスドメイン リクエストとは、ブラウザ内で、あるドメインの Web ページが別のドメインのリソースへのアクセスをリクエストすることを意味します。クロスドメイン リクエストは通常​​、AJAX リクエスト、画像/スクリプト/CSS 参照などで発生します。による

See all articles