這篇文章為大家帶來了關於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();
將多個角色同步到權限
$role->syncPermissions($permissions); // @param array $permissions $permission->syncRoles($roles);
從角色中刪除權限
$role->revokePermissionTo($permission); $permission->removeRole($role);取得目前的使用者的權限清單
$permissions = $user->permissions;取得使用者的所有權限,或直接權限(odel_has_permissions),或從角色獲取,或從兩者取得
$permissions = $user->getDirectPermissions(); $permissions = $user->getPermissionsViaRoles(); $permissions = $user->getAllPermissions();取得使用者的角色集合collection
$roles = $user->getRoleNames(); // Returns a collection傳回指定角色的使用者| Returns only users with the role 'writer'
$users = User::role('writer')->get(); //傳回指定權限的使用者
$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('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影片教學###】###
以上是一起聊聊Laravel中的permission權限管理的擴充包的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于单点登录的相关问题,单点登录是指在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于Laravel的生命周期相关问题,Laravel 的生命周期从public\index.php开始,从public\index.php结束,希望对大家有帮助。

在laravel中,guard是一个用于用户认证的插件;guard的作用就是处理认证判断每一个请求,从数据库中读取数据和用户输入的对比,调用是否登录过或者允许通过的,并且Guard能非常灵活的构建一套自己的认证体系。

laravel中asset()方法的用法:1、用于引入静态文件,语法为“src="{{asset(‘需要引入的文件路径’)}}"”;2、用于给当前请求的scheme前端资源生成一个url,语法为“$url = asset('前端资源')”。

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于使用中间件记录用户请求日志的相关问题,包括了创建中间件、注册中间件、记录用户访问等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于laravel的相关知识,其中主要介绍了关于中间件的相关问题,包括了什么是中间件、自定义中间件等等,中间件为过滤进入应用的 HTTP 请求提供了一套便利的机制,下面一起来看一下,希望对大家有帮助。

laravel路由文件在“routes”目录里。Laravel中所有的路由文件定义在routes目录下,它里面的内容会自动被框架加载;该目录下默认有四个路由文件用于给不同的入口使用:web.php、api.php、console.php等。

在laravel中,scope用于处理模型中的数据,在模型中可以定义scope开头方法,这类方法可以通过模型直接调用,被称为查询作用域,语法为“public function scope首字母大写单词($query){...}”。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

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

Dreamweaver Mac版
視覺化網頁開發工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。