做者:白狼 出處:http://www.manks.top/yii2_rbac_rule.html 本文版權歸做者,歡迎轉載,但未經做者贊成必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接,不然保留追究法律責任的權利。 在咱們以前yii2搭建後臺以及rbac詳細教程中,不知道你曾經疑惑過沒有一個問題,rule表是作什麼的,爲何在整個過程當中咱們都沒有涉及到這張表?php
相信我不說,部分人也都會去嘗試,或百度或google,到頭來也會竹籃打水,這部分講解的內容少之又少啊!html
對於通常的權限系統而言,咱們以前作的rbac通常狀況下是足夠的,即時沒有rule,相信你也能實現咱們用rule實現的功能。yii2
咱們就以官網的例子給出一個具體的操做教程,看看這個神祕的rule究竟是作什麼的!yii
看需求:網站
咱們有管理員和普通用戶,對於文章系統而言,咱們容許管理員對文章的任何操做,可是隻容許普通用戶建立文章和修改本身建立的文章,注意哦,是容許其修改本身建立的文章,不是不容許修改文章,也不是修改全部的文章!google
看yii2 rbac rule怎麼去實現,重點是教你們怎麼去使用這個rule,也解開衆多人心中的節!spa
在咱們添加rule以前,須要先實現 yii\rbac\Rule類的execute方法。code
<?php namespace backend\components; use Yii; use yii\rbac\Rule; class ArticleRule extends Rule { public $name = 'article'; public function execute($user, $item, $params) { // 這裏先設置爲false,邏輯上後面再完善 return false; } }
接着,咱們才能夠去後臺rule列表(/admin/rule/index)添加rule。具體添加方式可參考下方截圖component
(圖片見原文)htm
注意,上面這一步不少人會死在類名的添加上,記得加上咱們ArticleRule文件所在的命名空間!
咱們看第三步,該步驟也是很容易出錯的地方!該篇教程請注意集中精力,前方高能!
咱們訪問權限列表(/admin/permission/index)新增權限,該權限只針對文章的修改,隨後咱們將其分配給用戶所屬角色
須要注意了,此處嚴重警告,這裏新增長的權限所控制的路由也就是文章的更新操做(/article/update)分配給當前用戶僅且一次,重複分配當前操做給所屬角色或用戶,可能形成rule失效,失效緣由則是覆蓋!
此刻再次刷新文章的更新頁面(/article/update/1),很顯然直接給咱們了403 forbidden沒權限訪問的提示,也就是咱們剛剛添加的rule生效了!若是此刻沒生效,請檢查上面所說的兩個注意點!
而後咱們實現ArticleRule::execute方法內業務邏輯,可參考以下:
[考慮目前國內網站大部分採集文章十分頻繁,更有甚者不註明原文出處,原做者更但願看客們查看原文,以防有任何問題不能更新全部文章,避免誤導!]