이 글은 권한 권한 관리의 확장 패키지와 관련된 문제를 주로 소개하는 laravel에 대한 관련 지식을 제공합니다. 모두에게 도움이 되기를 바랍니다.
【관련 추천: laravel 비디오 튜토리얼】
다중 사용자 역할이란 무엇입니까
예를 들어, 예를 들어 우리가 일반적으로 사용하는 포럼
웹마스터 -------가 가장 높은 가장 중요한 권한입니다 유저를 관리하는 권한입니다
Administrator ----- 일부 글의 관리는 홈페이지 운영에 큰 영향을 미치지 않습니다
vip ----- 일부 리소스를 다운로드할 수 있는 권한
일반 사용자 ---- 자신의 기사에 대한 간단한 추가, 삭제, 수정, 댓글 등의 작업만 가능합니다.
방문자 ---- 기본 검색만 가능합니다.
테이블 생성
- Roles --- ---- 역할 정보 : 웹마스터 등
- permissions ------- 권한 정보 : 관리 콘텐츠 등
- model_has_roles ------- 모델 해당 역할 = 사용자 해당 역할
- role_has_permissions --- ---- 역할에 해당하는 권한 = 역할이 갖는 권한
- model_has_permissions ------- 모델에 해당하는 권한 = 사용자가 갖는 권한
관계를 정리해보자
권한 (권한) 및 역할 (역할), 하나의 권한은 여러 역할이 소유할 수 있으며 하나의 역할은 여러 권한을 가질 수 있습니다. 관계는 다대다(role_has_permissions)
user입니다. 및 permissions 일대다(model_has_permissions)
사용자 및 역할 일대다(model_has_roles)
이 경우 사용자가 어떤 역할을 가지고 있는지 또는 무엇을 가지고 있는지가 명확합니다.1. 확장 패키지 설치
composer require "spatie/laravel-permission:~2.7"데이터베이스 마이그레이션 파일 생성: php artisan Vendor:publish --provider="SpatiePermissionPermissionServiceProvider" --tag="migrations"볼 수 있습니다. 마이그레이션 디렉토리의 관련 테이블 정보, 데이터베이스 마이그레이션 실행
php artisan migrate구성 정보 생성:
php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="config"사용자 모델 아래 로드
..... 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']);// 创建权限
Use
사용자에게 권한 추가
$user->givePermissionTo('edit articles');Add 역할을 사용자에게
$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();가져오기 사용자의 역할 수집 컬렉션
$roles = $user->getRoleNames(); // Returns a collection지정된 역할을 가진 사용자 반환 | 'writer' 역할을 가진 사용자만 반환
$users = User::role('writer')->get(); //지정된 권한을 가진 사용자 반환
$users = User::permission('edit articles')->get();사용자에게는 어떤 역할이 있습니까?
$user->hasRole('writer');
Validation class
특정 권한이 있는지 확인
$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의 권한 관리 확장 패키지에 대해 이야기해 보겠습니다.의 상세 내용입니다. 자세한 내용은 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中,fill方法是一个给Eloquent实例赋值属性的方法,该方法可以理解为用于过滤前端传输过来的与模型中对应的多余字段;当调用该方法时,会先去检测当前Model的状态,根据fillable数组的设置,Model会处于不同的状态。

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


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

WebStorm Mac 버전
유용한 JavaScript 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
