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.
[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 performed1. Install the extension package
composer require "spatie/laravel-permission:~2.7"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 migrateGenerate configuration information:
php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="config"Load under the User model
..... use Spatie\Permission\Traits\HasRoles; // use class User extends Authenticatable { use HasRoles; // 加载角色相关信息 .....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']);// 创建权限
Use
Add permissions for users
$user->givePermissionTo('edit articles');Add roles for users
$user->assignRole('writer'); $user->assignRole(['writer', 'admin']);Delete permissions for users
$user->revokePermissionTo('edit articles');Add permissions for roles
$role->givePermissionTo('edit articles');Add permissions for roles Permissions
$role->givePermissionTo('edit articles');Revoke a permission and add a new one
$user->syncPermissions(['edit articles', 'delete articles']);Get the current user's role collection
$user->getRoleNames();Synchronize multiple roles to permissions
$role->syncPermissions($permissions); // @param array $permissions $permission->syncRoles($roles);Remove permissions from a role
$role->revokePermissionTo($permission); $permission->removeRole($role);Get the current user's permission list
$permissions = $user->permissions;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();Get the user's role collection collection
$roles = $user->getRoleNames(); // Returns a collectionReturns users with the specified role | Returns only users with the role 'writer'
$users = User::role('writer')->get(); //Returns users with the specified permissions
$users = User::permission('edit articles')->get();What roles does the user have
$user->hasRole('writer');
Verification class
Check whether there is a certain permission
$user->hasPermissionTo('edit articles'); $user->can('edit articles');Check whether there is a certain role | Or column
$user->hasRole('writer'); $user->hasAnyRole(Role::all()); $user->hasAllRoles(Role::all());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);Whether it has a set of permissions
$user->hasAnyPermission(['edit articles', 'publish articles', 'unpublish articles']);Check whether a role has certain permissions | Delete a certain These permissions
$role->hasPermissionTo('edit articles'); $role->revokePermissionTo('edit articles'); // 删除
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
data to filluse 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());
}
}
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');
[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!

本篇文章给大家带来了关于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中,fill方法是一个给Eloquent实例赋值属性的方法,该方法可以理解为用于过滤前端传输过来的与模型中对应的多余字段;当调用该方法时,会先去检测当前Model的状态,根据fillable数组的设置,Model会处于不同的状态。

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


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Atom editor mac version download
The most popular open source editor

Dreamweaver Mac version
Visual web development tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 English version
Recommended: Win version, supports code prompts!
