ホームページ PHPフレームワーク ThinkPHP ThinkPHP6 を使用して権限制御を実装する方法

ThinkPHP6 を使用して権限制御を実装する方法

Jun 20, 2023 pm 07:55 PM
thinkphp 成し遂げる 権限制御

インターネットがますます発展するにつれて、多くの Web サイトではユーザーのアクセス許可を制御する必要があります。アクセス許可制御により、システムのセキュリティを保護し、権限のないユーザーによるシステム リソースへのアクセスを防ぐことができます。これは商用アプリケーションでは非常に重要です。 PHP を使用してアプリケーションを開発する場合、ThinkPHP フレームワークはシンプルなソリューションを提供します。

ThinkPHP6 フレームワークは、RBAC (ロールベースのアクセス制御) に基づいた権限制御機能をユーザーに提供します。この記事では、権限の設定方法、コントローラーやビューでの権限の使用方法、権限制御情報をデータベースに保存する方法など、ThinkPHP6 を使用して権限制御を実装する方法を紹介します。

1. 基本概念

アクセス許可制御の実装方法を紹介する前に、いくつかの基本概念を理解する必要があります:

  1. ロール: は同じ機能を持ち、ユーザーは同じです承認管理を容易にするために、責任がロールに割り当てられます。
  2. 権限: ユーザーがシステム内でアクセスできるリソースと操作 (コントローラー、メソッド、ビューなど) を定義します。
  3. ロールと権限の関係: ロールを対応する権限に関連付けて、特定のロールを持つユーザーの承認管理を容易にします。

2. 権限の設定

  1. 権限の構成

ThinkPHP6 では、すべての権限の構成情報は appcontroller dmin.php に保存されます。ファイルの真ん中。構成ファイルには、パブリック アクセス許可とプライベート アクセス許可の 2 種類のアクセス許可があります。

パブリック権限とは、システムのホームページなど、すべてのユーザーがアクセスできるリソースと操作を指します。プライベート権限とは、特定の役割または権限を持つユーザーのみがアクセスできるリソースと操作を指します。

すべてのパブリック アクセス許可を appcontroller dmin.php ファイルに追加します:

return [
    // 公共权限
    'public' => [
        'index/index',
        'index/home'
    ],

    // 私有权限
    'private' => []
];
ログイン後にコピー
  1. プライベート アクセス許可を構成する

プライベート アクセス許可については、次のアクセス許可を追加する必要があります。 dmin.php ファイルのプライベート権限グループに追加します。

たとえば、AdminController コントローラーの getUserList メソッドへのアクセスを許可する「user」という名前の権限を追加できます:

// 私有权限
'private' => [
    'user' => [
        'AdminController/getUserList'
    ]
]
ログイン後にコピー

3. コントローラーとビューでの権限の使用

  1. 権限の確認
##特定の権限が必要なページにユーザーがアクセスするときは、ユーザーの権限を確認する必要があります。 ThinkPHP6 では、Auth クラスが提供する check メソッドを使用して、ユーザーが特定の権限を持っているかどうかを確認できます。

たとえば、次のメソッドを使用して、ユーザーが「user」という名前の権限を持っているかどうかを確認できます:

if (Auth::check('user')) {
    // 执行用户有权访问的操作
} else {
    // 返回无权访问页面
}
ログイン後にコピー

    現在のユーザーのロールを確認します
In 特定の操作を実行するときは、現在のユーザーの役割を理解し、その役割に基づいて適切に動作する必要があります。 ThinkPHP6 では、Auth クラスの getRole メソッドを使用して、現在のユーザーのロールを取得できます。

たとえば、次のメソッドを使用して現在のユーザーのロールを取得できます:

$role = Auth::getRole();
ログイン後にコピー

    ビューでのアクセス許可の使用
次のことができます。ビュー コントロールの権限を使用して、一部の要素を表示または非表示にすることもできます。たとえば、ブレード テンプレートでは、can ディレクティブを使用して、現在のユーザーが特定の権限を持っているかどうかを確認できます。

例:

<!-- 如果用户有'user'权限,则显示下面的按钮 -->
@can('user')
    <button type="button" class="btn btn-sm btn-primary">操作</button>
@endcan
ログイン後にコピー

4. 権限制御情報をデータベースに保存する

権限制御をより柔軟にするために、権限情報をデータベースに保存して管理を容易にすることができます。 . および修正。 ThinkPHP6 は、データベースから許可情報を簡単に読み取って検証できる Auth クラスを提供します。

データベースに権限を設定する場合、4 つのテーブルを作成する必要があります:

    ユーザー テーブル (ユーザー): ユーザー ID、ユーザー名、パスワードなどのユーザー情報を保存します。
  1. ロール テーブル (ロール): ロール ID やロール名などのロール情報を保存します。
  2. 権限テーブル (権限): 権限 ID や権限名などの権限情報を保存します。
  3. ロール権限テーブル (role_permission): ロールと権限の間の関係情報を格納します。
Auth クラスでは、次のメソッドを使用して検証用のテーブル名を設定します。

protected $table = [
    'auth' => 'auth',
    'users' => 'users',
    'roles' => 'roles',
    'permissions' => 'permissions',
    'role_permissions' => 'role_permission'
];
ログイン後にコピー
上記は、ThinkPHP6 を使用して権限制御を実装するプロセス全体です。以上の操作により、RBACベースの権限制御を簡単に実装することができ、プロジェクトのセキュリティと制御性を向上させることができます。

以上がThinkPHP6 を使用して権限制御を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、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衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

thinkphpプロジェクトの実行方法 thinkphpプロジェクトの実行方法 Apr 09, 2024 pm 05:33 PM

ThinkPHP プロジェクトを実行するには、Composer をインストールし、Composer を使用してプロジェクトを作成し、プロジェクト ディレクトリに入り、php bin/consoleserve を実行し、http://localhost:8000 にアクセスしてようこそページを表示する必要があります。

Huawei 携帯電話にデュアル WeChat ログインを実装するにはどうすればよいですか? Huawei 携帯電話にデュアル WeChat ログインを実装するにはどうすればよいですか? Mar 24, 2024 am 11:27 AM

Huawei 携帯電話にデュアル WeChat ログインを実装するにはどうすればよいですか?ソーシャルメディアの台頭により、WeChatは人々の日常生活に欠かせないコミュニケーションツールの1つになりました。ただし、多くの人は、同じ携帯電話で同時に複数の WeChat アカウントにログインするという問題に遭遇する可能性があります。 Huawei 社の携帯電話ユーザーにとって、WeChat の二重ログインを実現することは難しくありませんが、この記事では Huawei 社の携帯電話で WeChat の二重ログインを実現する方法を紹介します。まず第一に、ファーウェイの携帯電話に付属するEMUIシステムは、デュアルアプリケーションを開くという非常に便利な機能を提供します。アプリケーションのデュアルオープン機能により、ユーザーは同時に

thinkphp にはいくつかのバージョンがあります thinkphp にはいくつかのバージョンがあります Apr 09, 2024 pm 06:09 PM

ThinkPHP には、さまざまな PHP バージョン向けに設計された複数のバージョンがあります。メジャー バージョンには 3.2、5.0、5.1、および 6.0 が含まれますが、マイナー バージョンはバグを修正し、新機能を提供するために使用されます。最新の安定バージョンは ThinkPHP 6.0.16 です。バージョンを選択するときは、PHP バージョン、機能要件、コミュニティ サポートを考慮してください。最高のパフォーマンスとサポートを得るには、最新の安定バージョンを使用することをお勧めします。

thinkphpの実行方法 thinkphpの実行方法 Apr 09, 2024 pm 05:39 PM

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

PHP プログラミング ガイド: フィボナッチ数列を実装する方法 PHP プログラミング ガイド: フィボナッチ数列を実装する方法 Mar 20, 2024 pm 04:54 PM

プログラミング言語 PHP は、さまざまなプログラミング ロジックやアルゴリズムをサポートできる、Web 開発用の強力なツールです。その中でも、フィボナッチ数列の実装は、一般的で古典的なプログラミングの問題です。この記事では、PHP プログラミング言語を使用してフィボナッチ数列を実装する方法を、具体的なコード例を添付して紹介します。フィボナッチ数列は、次のように定義される数学的数列です。数列の最初と 2 番目の要素は 1 で、3 番目の要素以降、各要素の値は前の 2 つの要素の合計に等しくなります。シーケンスの最初のいくつかの要素

Huawei携帯電話にWeChatクローン機能を実装する方法 Huawei携帯電話にWeChatクローン機能を実装する方法 Mar 24, 2024 pm 06:03 PM

Huawei 携帯電話に WeChat クローン機能を実装する方法 ソーシャル ソフトウェアの人気と人々のプライバシーとセキュリティの重視に伴い、WeChat クローン機能は徐々に人々の注目を集めるようになりました。 WeChat クローン機能を使用すると、ユーザーは同じ携帯電話で複数の WeChat アカウントに同時にログインできるため、管理と使用が容易になります。 Huawei携帯電話にWeChatクローン機能を実装するのは難しくなく、次の手順に従うだけです。ステップ 1: 携帯電話システムのバージョンと WeChat のバージョンが要件を満たしていることを確認する まず、Huawei 携帯電話システムのバージョンと WeChat アプリが最新バージョンに更新されていることを確認します。

laravelとthinkphpではどちらが優れていますか? laravelとthinkphpではどちらが優れていますか? Apr 09, 2024 pm 03:18 PM

Laravel フレームワークと ThinkPHP フレームワークのパフォーマンスの比較: ThinkPHP は、最適化とキャッシュに重点を置いて、一般に Laravel よりもパフォーマンスが優れています。 Laravel は優れたパフォーマンスを発揮しますが、複雑なアプリケーションの場合は、ThinkPHP の方が適している可能性があります。

Golang がゲーム開発の可能性を可能にする方法をマスターする Golang がゲーム開発の可能性を可能にする方法をマスターする Mar 16, 2024 pm 12:57 PM

今日のソフトウェア開発分野では、効率的で簡潔かつ同時実行性の高いプログラミング言語として、Golang (Go 言語) が開発者にますます好まれています。豊富な標準ライブラリと効率的な同時実行機能により、ゲーム開発の分野で注目を集めています。この記事では、ゲーム開発に Golang を使用する方法を検討し、具体的なコード例を通じてその強力な可能性を示します。 1. ゲーム開発における Golang の利点 Golang は静的型付け言語として、大規模なゲーム システムの構築に使用されます。

See all articles