我們先使用laravel-admin後台實作一個權限管理
1.新增一個使用者管理的權限
標識(slug)是用來標記權限的唯一標識,全域唯一。名稱(name)是這個權限的展示名稱,要讓人一眼看明白這個權限是做什麼用的
2.新增一個角色
#3.建立管理員
這樣的話,我們就有了kaka這個用戶,然後我們來登入一下,我們只給了這個kaka一個用戶管理的權限,這樣就設定成功了。
解析權限管理
#實作權限管理資料表
1.我們先來看看admin_user表,這只是一個單純保存後台管理員的一個表。
2.下面就是我們的角色表,也就是我們在laravel-admin後台加入角色就會加入這個表裡面。
3.下來就是重點來了,我們的角色使用者表。
我們可以看到角色使用者表,裡面有個角色id跟使用者id的外鍵,這個表就是把管理員跟角色連結在一起了。
4.下面就是權限表,這個表是儲存的所有的權限。
5.最後就是我們的角色權限表了。
權限總結
上邊給大家看了具體的表格結構,其實這個不是很複雜,我們在簡單的闡述一下:
首先我們在做權限管理的時候為了什麼,那就是希望不同的管理員看到不同的內容。
1.那麼我們需要的第一個表格就是後台管理員表admin_users,這個表只是用來儲存管理員帳號和密碼;
2.在一個基本上那就是我們的角色表admin_roles,這個表的性質跟管理員表是一樣的也是來存儲角色的信息;
#3.那麼這個時候就需要一個表來關聯我們的admin_users和admin_roles表,那就是admin_role_users,這個表只是一個中間件表,裡邊只需要把管理員跟角色的對應關係存儲即可;
4.上邊都完善了後我們就需要一個權限表了admin_permissions,這個表就是存儲我們所有的權限;
5.那我們的權限是不是需要跟角色關聯呢!只有這樣使用者才可以從自己的角色中取得到自己擁有的權限,那麼就需要一個權限角色表admin_role_permissions。
python學習網,大量的免費laravel入門教學,歡迎線上學習!
以上是laravel-admin權限管理與實作原理的詳細內容。更多資訊請關注PHP中文網其他相關文章!