ホームページ >バックエンド開発 >PHPチュートリアル >Yii2 がバックエンドを構築し、rbac 権限制御を実装する完全なサンプル チュートリアル、yii2rbac_PHP チュートリアル
1 を実装します。 まだインストールしていない場合は、yii2 の歴史の中で唯一、最も簡単なインストールチュートリアルを参照してください
すでにインストールしている場合は、次のステップに進んでください2. データベースを構成します
2.1 構成データベース
common/config/main-local.php を変更します。実際のプロジェクトでは、ローカル データベースがオンライン データベースと一致しないことがよくあります。 ここで main-local.php を設定するだけで済みます。製品がオンラインになったら、git または svn を使用して main-local.php を無視し、オンラインで直接デプロイできます。
ここで使用するmysqlデータベースは次のように構成されています
もちろん、上記の赤丸で囲った情報は手動で修正する必要がありますが、万が一私のものと同じであれば、修正する必要はありません。
2.2 ユーザーデータテーブルを作成します。後でバックグラウンドログインを実装します
注: ユーザー テーブルとメニュー テーブルを作成するには、後でダウンロードしたコンポーネント yii2-admin 内の SQL を参照できます。特定のディレクトリは
にあります。 リーリー 2.3 まずフロントエンドサイトにアクセスしてユーザー登録をします
登録が成功すると、右上隅にログインステータスが表示されます。この登録されたユーザーは後で使用します。
次に、背景テンプレートの構成を開始する必要があります。
3. AdminLTE を使用して背景テンプレートをレンダリングします
背景テンプレートにはAdminLTE (Yii2 Frameworkのバックエンドテーマ)を使用します 簡単な余談: AdminLTE は完全に応答性の高い管理テンプレートです。 Bootstrap3 フレームワークに基づいているため、テンプレートのカスタマイズが簡単です。小型モバイルデバイスから大型デスクトップまで、さまざまな画面解像度に適合します。 ダッシュボード、電子メール、カレンダー、ロック画面、ログインと登録、404 エラー、500 エラー、その他のページを含む複数のページが組み込まれています。
3.1 AdminLTEをインストールするhttps://github.com/dmstr/yii2-adminlte-asset
上記のリンクを開いて、手順に従ってインストールしてください ここでは、CD Advanced を実行した後のインストール手順を簡単に説明します
Macなのでcomposerを使って直接インストールしてください
コンポーザーには dmstr/yii2-adminlte-asset "2.*" が必要です
インストールが成功すると、次のように、ベンダー ディレクトリにさらにいくつかのフォルダーが作成されます
3.2 yii2 構成は AdminLTE を統合して、優れたハイエンド バックエンドを構築します
最初に backend/config/main.php を設定して効果をプレビューしましょう。心配な場合は、結果を試してみてください。 リーリー
いいですね、ページの見栄えがすぐに良くなりました。
ここで問題が発生します。テーマをコンポーネントで個別に設定しているため、後でレイアウト ファイルを変更するのが非常に不便です。次に、残りのファイルをコピーして、Yii に付属のレイアウトを上書きします。
レイアウトとサイトをvendor/dmstr/yii2-adminlte-asset/example-views/yiisoft/yii2-appディレクトリにコピーしますbackend/views/ディレクトリ内のlauoutsとsiteに対応するファイルを上書きします
上書き後、コンポーネントの下のビューの設定項目を忘れずにブロックしてください
この時点で、背景テンプレートの構築が完了しました。とても嬉しいです
4. 次に、Yii の rbac を使用してバックグラウンド権限制御を実装します
4.1 まず短いルートを設定しましょうbackend/config/main.php ファイルのコンポーネントと次の構成 リーリー 次に、プロジェクトのルートディレクトリである backend/web に .htaccess ファイルを作成し、次の内容を追加します。このファイルを作成することさえできません。 リーリー
もちろん、Apache は書き換えモジュールを有効にする必要があります。giiモジュールにアクセスしてテストしてみましょう
http://localhost/advanced/backend/web/gii検証可能です。
4.2 権限制御に必要なデータテーブルを作成する
もちろん、これらの yii2 は準備ができています。
vendor/yiisoft/yii2/rbac/migrations/schema-mysql.sql ファイルを開き、データテーブルを順番に作成します
リーリー
さらにメニューテーブルを追加し、必要に応じて自分で作成します注: ユーザー テーブルとメニュー テーブルを作成するには、vendormdmsoftyii2-adminmigrationsschema-mysql.sql を参照してください リーリー
4.3 yii2-adminをダウンロードしてインストールします
参考 https://github.com/mdmsoft/yii2-admin
adminlteのインストールと同じ手順に従って、段階的にインストールしてください
インストール後、vendor ディレクトリの下に mdmsoft ディレクトリが表示されます
4.4 権限の構成
backend/config/main.php を開いて構成を変更します
'modules' => [ 'admin' => [ 'class' => 'mdm\admin\Module', ], ], 'aliases' => [ '@mdm/admin' => '@vendor/mdmsoft/yii2-admin', ], //这里必须添加authManager配置项 'components' => [ ... //components数组中加入authManager组件,有PhpManager和DbManager两种方式, //PhpManager将权限关系保存在文件里,这里使用的是DbManager方式,将权限关系保存在数据库. 'authManager' => [ 'class' => 'yii\rbac\DbManager', 'defaultRoles' => ['guest'], ], ... ],
4.5 我们访问下权限模块检验下效果如何
http://localhost/advanced/backend/web/admin/route
嗯,界面是有的了,下面我们加快脚步验收下我们的权限这块到底成还是不成呢?
一般来说到这一步就ok的了。后面的可以自己摸索着添加路由分配权限了。
下面我们在左侧菜单上把权限的栏目加上,代码可直接复制,放置于 e744ef80d1d94e1d4d637457ed3fa8f54d7ab0de9a42de71c682b0860bad1410内
<ul class="sidebar-menu"> <li class="treeview"> <a href="#"> <i class="fa fa-gears"></i> <span>权限控制</span> <i class="fa fa-angle-left pull-right"></i> </a> <ul class="treeview-menu"> <li class="treeview"> <a href="/admin">管理员</a> <ul class="treeview-menu"> <li><a href="/user"><i class="fa fa-circle-o"></i> 后台用户</a></li> <li class="treeview"> <a href="/admin/role"> <i class="fa fa-circle-o"></i> 权限 <i class="fa fa-angle-left pull-right"></i> </a> <ul class="treeview-menu"> <li><a href="/admin/route"><i class="fa fa-circle-o"></i> 路由</a></li> <li><a href="/admin/permission"><i class="fa fa-circle-o"></i> 权限</a></li> <li><a href="/admin/role"><i class="fa fa-circle-o"></i> 角色</a></li> <li><a href="/admin/assignment"><i class="fa fa-circle-o"></i> 分配</a></li> <li><a href="/admin/menu"><i class="fa fa-circle-o"></i> 菜单</a></li> </ul> </li> </ul> </li> </ul> </li> </ul>
我们看下效果图,这样一来,我们对权限进行操作就十分的方便了
如此,我们的权限控制基本告一段落了,关于权限需要说明的是:
你应该先添加路由,然后添加权限名称,后再对角色或个人进行权限的独立分配。
5、如何利用menu对菜单进行控制?
4.5步骤中我们是直接写ul li的方式对左侧菜单进行操作的,这样也是能够实现通过菜单对权限进行控制滴。
但是喃,一来不方便操作,而来增加修改个什么东东都得需要我们去修改程序实现,这也TTM不方便了。还好我们家有妙招,DDV杀杀杀。
好了,又扯远了。仔细回想,是不是我们创建的123456张表还有一张menu表没有利用到喃?这货怎么利用喃?来,我们回归正题。
首选,我们访问/admin/menu/index添加几个一级菜单,姑且叫做一级1,一级2,一级3吧,哦对了,忘记添加路由了,怎么回事呢,我们先访问/admin/route/index 把左侧的路由移动到右侧,不然上面创建新菜单会失败哦。创建菜单时,[映射][数据]我们暂且不填写。
添加完毕之后呢,我们打开布局文件left.php,use两个类文件,分别是yii\bootstrap\Nav和mdm\admin\components\MenuHelper;
获取权限的操作 MenuHelper::getAssignedMenu都帮我们做好了。
ok,我们删掉4.5添加的sidebar-menu菜单,添加下面的代码试试看
echo Nav::widget( [ 'encodeLabels' => false, 'options' => ['class' => 'sidebar-menu'], 'items' => MenuHelper::getAssignedMenu(Yii::$app->user->id), ] );
现在菜单控制权限我们基本上是ok了,现在你可以继续添加菜单试试效果如何。
到此呢,我们的后台和rbac的权限控制可以说是做得非常完美了,如果你在尝试的过程中遇到任何问题,下面留言就好,咱们共同交流探讨。
相关阅读:
Yii2 rbac权限控制之菜单menu实例教程