Table of Contents
What is a multi-user role
Create tables
Home PHP Framework Laravel Let's talk about the permission management expansion package in Laravel

Let's talk about the permission management expansion package in Laravel

May 02, 2022 am 09:00 AM
laravel

This article brings you relevant knowledge about laravel, which mainly introduces the issues related to the expansion package of permission permission management. Let’s take a look at it together. I hope it will be helpful to everyone.

Let's talk about the permission management expansion package in Laravel

[Related recommendations: laravel video tutorial]

What is a multi-user role

For example, For example, the forum we usually use

Webmaster------has the highest authority, and the most important thing is the authority to manage users

Administrator-----For some The management of articles will not have a major impact on the website

vip ----- Have download permission for some resources

Ordinary users ---- can only make simple edits Additions, deletions, modifications, comments, etc. of your own articles

Visitors ---- can only perform basic browsing

Create tables


  • roles ------- Role information: Webmaster, etc.
  • permissions ------- Permission information: Management content, etc.
  • model_has_roles ------- Role corresponding to the model = Role corresponding to the user
  • role_has_permissions ------- Permission corresponding to the role = What permissions does the role have
  • model_has_permissions ----- -- Model corresponding permissions = Users have permissions

Let’s sort out the relationships

##Permissions (permissions) and Role (roles), one permission may be owned by multiple roles, and one role may have multiple permissions. Association relationship: many-to-many (role_has_permissions)

User and Permissions One-to-many (model_has_permissions)

User and Role One-to-many (model_has_roles)

By times Said, the relationship is clear, when the user has what role or what permissions, the corresponding operation is performed

1. Install the extension package

composer require "spatie/laravel-permission:~2.7"
Copy after login
Generate database migration file:

php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="migrations"

You can see related table information in the migration directory and perform database migration

php artisan migrate
Copy after login
Generate configuration information:

php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="config"
Copy after login
Load under the User model

.....
use Spatie\Permission\Traits\HasRoles;  // use

class User extends Authenticatable
{

    use HasRoles;  // 加载角色相关信息
    .....
Copy after login
Create roles and users

use Spatie\Permission\Models\Role;
use Spatie\Permission\Models\Permission;

.....
$role = Role::create(['name' => 'writer']);  // 创建角色
$permission = Permission::create(['name' => 'edit articles']);// 创建权限
Copy after login

Use


Add permissions for users

$user->givePermissionTo('edit articles');
Copy after login
Add roles for users

$user->assignRole('writer');

$user->assignRole(['writer', 'admin']);
Copy after login
Delete permissions for users

$user->revokePermissionTo('edit articles');
Copy after login
Add permissions for roles

$role->givePermissionTo('edit articles');
Copy after login
Copy after login
Add permissions for roles Permissions

$role->givePermissionTo('edit articles');
Copy after login
Copy after login
Revoke a permission and add a new one

$user->syncPermissions(['edit articles', 'delete articles']);
Copy after login
Get the current user's role collection

$user->getRoleNames();
Copy after login
Synchronize multiple roles to permissions

$role->syncPermissions($permissions); //  @param array $permissions

$permission->syncRoles($roles);
Copy after login
Remove permissions from a role

$role->revokePermissionTo($permission);
$permission->removeRole($role);
Copy after login
Get the current user's permission list

$permissions = $user->permissions;
Copy after login
Get all the user's permissions, or direct permissions (odel_has_permissions), or get it from the role, or get it from both

$permissions = $user->getDirectPermissions();
$permissions = $user->getPermissionsViaRoles();
$permissions = $user->getAllPermissions();
Copy after login
Get the user's role collection collection

$roles = $user->getRoleNames(); // Returns a collection
Copy after login
Returns users with the specified role | Returns only users with the role 'writer'

$users = User::role('writer')->get(); //
Copy after login
Returns users with the specified permissions

$users = User::permission('edit articles')->get();
Copy after login
What roles does the user have

$user->hasRole('writer');
Copy after login

Verification class


Check whether there is a certain permission

$user->hasPermissionTo('edit articles');

$user->can('edit articles');
Copy after login
Check whether there is a certain role | Or column

$user->hasRole('writer');

$user->hasAnyRole(Role::all());

$user->hasAllRoles(Role::all());
Copy after login
pass the id value to determine whether there is a certain permission

$user->hasPermissionTo('1');
$user->hasPermissionTo(Permission::find(1)->id);
$user->hasPermissionTo($somePermission->id);
Copy after login
Whether it has a set of permissions

$user->hasAnyPermission(['edit articles', 'publish articles', 'unpublish articles']);
Copy after login
Check whether a role has certain permissions | Delete a certain These permissions

$role->hasPermissionTo('edit articles'); 

$role->revokePermissionTo('edit articles'); // 删除
Copy after login

template uses

@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
Copy after login

data to fill
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());
    }
}
Copy after login

Tip: If in the database To modify the permission-related information table, you must use the method of clearing the cache
// 命令删除
php artisan cache:forget spatie.permission.cache  

app()['cache']->forget('spatie.permission.cache');
Copy after login

[Related recommendations:

laravel video tutorial]

The above is the detailed content of Let's talk about the permission management expansion package in Laravel. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to get the return code when email sending fails in Laravel? How to get the return code when email sending fails in Laravel? Apr 01, 2025 pm 02:45 PM

Method for obtaining the return code when Laravel email sending fails. When using Laravel to develop applications, you often encounter situations where you need to send verification codes. And in reality...

How to implement the custom table function of clicking to add data in dcat admin? How to implement the custom table function of clicking to add data in dcat admin? Apr 01, 2025 am 07:09 AM

How to implement the table function of custom click to add data in dcatadmin (laravel-admin) When using dcat...

Laravel Redis connection sharing: Why does the select method affect other connections? Laravel Redis connection sharing: Why does the select method affect other connections? Apr 01, 2025 am 07:45 AM

The impact of sharing of Redis connections in Laravel framework and select methods When using Laravel framework and Redis, developers may encounter a problem: through configuration...

Laravel multi-tenant extension stancl/tenancy: How to customize the host address of a tenant database connection? Laravel multi-tenant extension stancl/tenancy: How to customize the host address of a tenant database connection? Apr 01, 2025 am 09:09 AM

Custom tenant database connection in Laravel multi-tenant extension package stancl/tenancy When building multi-tenant applications using Laravel multi-tenant extension package stancl/tenancy,...

Laravel Eloquent ORM in Bangla partial model search) Laravel Eloquent ORM in Bangla partial model search) Apr 08, 2025 pm 02:06 PM

LaravelEloquent Model Retrieval: Easily obtaining database data EloquentORM provides a concise and easy-to-understand way to operate the database. This article will introduce various Eloquent model search techniques in detail to help you obtain data from the database efficiently. 1. Get all records. Use the all() method to get all records in the database table: useApp\Models\Post;$posts=Post::all(); This will return a collection. You can access data using foreach loop or other collection methods: foreach($postsas$post){echo$post->

How to effectively check the validity of Redis connections in Laravel6 project? How to effectively check the validity of Redis connections in Laravel6 project? Apr 01, 2025 pm 02:00 PM

How to check the validity of Redis connections in Laravel6 projects is a common problem, especially when projects rely on Redis for business processing. The following is...

Laravel database migration encounters duplicate class definition: How to resolve duplicate generation of migration files and class name conflicts? Laravel database migration encounters duplicate class definition: How to resolve duplicate generation of migration files and class name conflicts? Apr 01, 2025 pm 12:21 PM

A problem of duplicate class definition during Laravel database migration occurs. When using the Laravel framework for database migration, developers may encounter "classes have been used...

Laravel Introduction Example Laravel Introduction Example Apr 18, 2025 pm 12:45 PM

Laravel is a PHP framework for easy building of web applications. It provides a range of powerful features including: Installation: Install the Laravel CLI globally with Composer and create applications in the project directory. Routing: Define the relationship between the URL and the handler in routes/web.php. View: Create a view in resources/views to render the application's interface. Database Integration: Provides out-of-the-box integration with databases such as MySQL and uses migration to create and modify tables. Model and Controller: The model represents the database entity and the controller processes HTTP requests.

See all articles