一起聊聊Laravel中的permission權限管理的擴充包
這篇文章為大家帶來了關於laravel的相關知識,其中主要介紹了關於permission權限管理的擴充包相關問題,下面一起來看一下,希望對大家有幫助。
【相關推薦:laravel影片教學】
什麼是多用戶角色
舉個例子,例如我們平常使用的論壇
站長------ 擁有最高權限,最主要的是能夠對使用者進行管理的權限
管理員----- 對一些文章的管理,不會造成對網站有較大的影響
vip ----- 對一些資源有下載權限
普通用戶---- 只能夠進行簡單的對自己文章的增刪改、評論等
遊客---- 只能進行基本的瀏覽
roles ------- 角色資訊:站長等
permissions ------- 權限資訊:管理內容等 model_has_roles ------- 模型對應角色= 使用者對應的角色role_has_permissions ------- 角色對應權限= 角色有什麼權限
model_has_permissions ----- -- 模型對應權限= 使用者有權限我們來梳理一下關聯關係
權限(permissions)與
角色
(roles) ,一個權限可能被多個角色擁有,一個角色可能有多個權限,關聯關係:多對多(role_has_permissions)用戶
與權限
一對多(model_has_permissions)使用者
與角色
一對多(model_has_roles)#由次來說,關係明確了,當使用者有什麼角色或有什麼權限,即執行對應的操作
#1. 安裝擴充包
composer require "spatie/laravel-permission:~2.7"
產生資料庫遷移檔:
php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="migrations"
在migration 目錄下可看到相關表格信息,執行資料庫遷移
php artisan migrate
產生設定資訊:
php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="config"
在User 模型下載入
..... use Spatie\Permission\Traits\HasRoles; // use class User extends Authenticatable { use HasRoles; // 加载角色相关信息 .....
建立角色和使用者
use Spatie\Permission\Models\Role; use Spatie\Permission\Models\Permission; ..... $role = Role::create(['name' => 'writer']); // 创建角色 $permission = Permission::create(['name' => 'edit articles']);// 创建权限
##使用
為使用者新增權限
$user->givePermissionTo('edit articles');
為使用者新增角色
$user->assignRole('writer'); $user->assignRole(['writer', 'admin']);
給使用者刪除權限
$user->revokePermissionTo('edit articles');
給角色新增權限
$role->givePermissionTo('edit articles');
為角色新增權限
$role->givePermissionTo('edit articles');
撤銷一個權限並且新增一個新權限
$user->syncPermissions(['edit articles', 'delete articles']);
取得目前使用者的角色集合$user->getRoleNames();
登入後複製將多個角色同步到權限
$user->getRoleNames();
$role->syncPermissions($permissions); // @param array $permissions $permission->syncRoles($roles);
從角色中刪除權限
$role->revokePermissionTo($permission); $permission->removeRole($role);
$permissions = $user->permissions;
$permissions = $user->getDirectPermissions(); $permissions = $user->getPermissionsViaRoles(); $permissions = $user->getAllPermissions();
$roles = $user->getRoleNames(); // Returns a collection
$users = User::role('writer')->get(); //
$users = User::permission('edit articles')->get();
登入後複製 使用者有什麼角色$user->hasRole('writer');
登入後複製
$users = User::permission('edit articles')->get();
$user->hasRole('writer');
驗證類別
#檢查是否有某個權限
$user->hasPermissionTo('edit articles');
$user->can('edit articles');
登入後複製
檢查是否有某個角色| 或列$user->hasRole('writer');
$user->hasAnyRole(Role::all());
$user->hasAllRoles(Role::all());
登入後複製
傳遞id 值進行判斷是否有某個權限
$user->hasPermissionTo('edit articles'); $user->can('edit articles');
$user->hasRole('writer'); $user->hasAnyRole(Role::all()); $user->hasAllRoles(Role::all());
$user->hasPermissionTo('1'); $user->hasPermissionTo(Permission::find(1)->id); $user->hasPermissionTo($somePermission->id);
$user->hasAnyPermission(['edit articles', 'publish articles', 'unpublish articles']);
$role->hasPermissionTo('edit articles'); $role->revokePermissionTo('edit articles'); // 删除
@role('writer') I am a writer! @else I am not a writer... @endrole ------------------------ @hasrole('writer') I am a writer! @else I am not a writer... @endhasrole ------------------------ @can('edit articles') // 拥有某个权限 可执行操作 // @endcan
use Illuminate\Database\Seeder; use Spatie\Permission\Models\Role; use Spatie\Permission\Models\Permission; class RolesAndPermissionsSeeder extends Seeder { public function run() { // Reset cached roles and permissions app()['cache']->forget('spatie.permission.cache'); // create permissions Permission::create(['name' => 'edit articles']); Permission::create(['name' => 'delete articles']); Permission::create(['name' => 'publish articles']); Permission::create(['name' => 'unpublish articles']); // create roles and assign created permissions $role = Role::create(['name' => 'writer']); $role->givePermissionTo('edit articles'); $role = Role::create(['name' => 'moderator']); $role->givePermissionTo(['publish articles', 'unpublish articles']); $role = Role::create(['name' => 'super-admin']); $role->givePermissionTo(Permission::all()); } }
// 命令删除 php artisan cache:forget spatie.permission.cache app()['cache']->forget('spatie.permission.cache');
以上是一起聊聊Laravel中的permission權限管理的擴充包的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

使用ORM可簡化PHP中的資料庫操作,它將物件對應到關聯式資料庫中。 Laravel中的EloquentORM允許使用物件導向的語法與資料庫交互,可透過定義模型類別、使用Eloquent方法或在實戰中建立部落格系統等方式來使用ORM。

Laravel9和CodeIgniter4的最新版本提供了更新的功能和改進。 Laravel9採用MVC架構,提供資料庫遷移、驗證及模板引擎等功能。 CodeIgniter4採用HMVC架構,提供路由、ORM和快取。在性能方面,Laravel9的基於服務提供者設計模式和CodeIgniter4的輕量級框架使其具有出色的性能。在實際應用中,Laravel9適用於需要靈活性和強大功能的複雜項目,而CodeIgniter4適用於快速開發和小型應用程式。

比較Laravel和CodeIgniter的資料處理能力:ORM:Laravel使用EloquentORM,提供類別物件關係映射,而CodeIgniter使用ActiveRecord,將資料庫模型表示為PHP類別的子類別。查詢建構器:Laravel具有靈活的鍊式查詢API,而CodeIgniter的查詢建構器更簡單,基於陣列。資料驗證:Laravel提供了一個Validator類,支援自訂驗證規則,而CodeIgniter的驗證功能內建較少,需要手動編碼自訂規則。實戰案例:用戶註冊範例展示了Lar

Laravel - Artisan 指令 - Laravel 5.7 提供了處理和測試新指令的新方法。它包括測試 artisan 命令的新功能,下面提到了演示?

對於初學者來說,CodeIgniter的學習曲線更平緩,功能較少,但涵蓋了基本需求。 Laravel提供了更廣泛的功能集,但學習曲線稍陡。在性能方面,Laravel和CodeIgniter都表現出色。 Laravel有更廣泛的文件和活躍的社群支持,而CodeIgniter更簡單、輕量級,具有強大的安全功能。在建立部落格應用程式的實戰案例中,Laravel的EloquentORM簡化了資料操作,而CodeIgniter需要更多的手動配置。

在選擇大型專案框架時,Laravel和CodeIgniter各有優勢。 Laravel針對企業級應用程式而設計,提供模組化設計、相依性注入和強大的功能集。 CodeIgniter是一款輕量級框架,更適合小型到中型項目,強調速度和易用性。對於具有複雜需求和大量用戶的大型項目,Laravel的強大功能和可擴展性更為合適。而對於簡單專案或資源有限的情況下,CodeIgniter的輕量級和快速開發能力則較為理想。

微服務架構使用PHP框架(如Symfony和Laravel)來實現微服務,並遵循RESTful原則和標準資料格式來設計API。微服務透過訊息佇列、HTTP請求或gRPC進行通信,並使用工具(如Prometheus和ELKStack)進行監控和故障排除。

對於小型項目,Laravel適用於大型項目,需要強大的功能和安全性。 CodeIgniter適用於非常小的項目,需要輕量級和易用性。
