Rumah > rangka kerja php > Laravel > Aplikasi praktikal fungsi kebenaran Laravel: Cara melaksanakan kawalan kebenaran struktur organisasi pengguna

Aplikasi praktikal fungsi kebenaran Laravel: Cara melaksanakan kawalan kebenaran struktur organisasi pengguna

PHPz
Lepaskan: 2023-11-02 08:17:03
asal
1330 orang telah melayarinya

Aplikasi praktikal fungsi kebenaran Laravel: Cara melaksanakan kawalan kebenaran struktur organisasi pengguna

Aplikasi praktikal fungsi kebenaran Laravel: Cara melaksanakan kawalan kebenaran struktur organisasi pengguna memerlukan contoh kod khusus

Pengenalan:
Dengan perkembangan pesat aplikasi web, kawalan kebenaran pengguna telah menjadi keperluan fungsi yang penting. Laravel, sebagai rangka kerja PHP yang popular, menyediakan fungsi pengurusan kebenaran yang fleksibel dan berkuasa. Artikel ini akan memperkenalkan cara menggunakan Laravel untuk melaksanakan kawalan kebenaran struktur organisasi pengguna dan memberikan contoh kod khusus.

1. Keperluan untuk kawalan kebenaran struktur organisasi pengguna
Dalam banyak aplikasi, kebenaran pengguna biasanya diperuntukkan dan diuruskan mengikut struktur organisasi. Sebagai contoh, perusahaan mempunyai beberapa jabatan, dan setiap jabatan mempunyai pekerja yang berbeza. Dalam kes ini, fungsi yang perlu dilaksanakan ialah:

  1. Pentadbir jabatan boleh menguruskan pekerja di bawah jabatan mereka sendiri, tetapi tidak boleh mengakses maklumat daripada jabatan lain
  2. Eksekutif boleh mengakses dan mengurus data keseluruhan syarikat
  3. ; Pekerja Am hanya boleh mengakses maklumat peribadi mereka sendiri.

2. Gunakan fungsi pengurusan kebenaran Laravel
Rangka kerja Laravel mempunyai set lengkap fungsi pengurusan kebenaran terbina dalam yang boleh memenuhi keperluan di atas. Berikut akan memperkenalkan cara menggunakan fungsi kebenaran Laravel untuk melaksanakan kawalan kebenaran struktur organisasi pengguna.

  1. Pasang pemalam pengurusan kebenaran Laravel
    Mula-mula, pasang pemalam pengurusan kebenaran dalam projek Laravel Yang biasa digunakan ialah spatie/laravel-permission dan laravel-permission. Di sini, spatie/laravel-permission digunakan sebagai contoh untuk demonstrasi. Jalankan arahan berikut dalam baris arahan untuk memasang:
composer require spatie/laravel-permission
Salin selepas log masuk

Kemudian, tambahkan konfigurasi berikut dalam fail config/app.php:

'providers' => [
    // ...
    SpatiePermissionPermissionServiceProvider::class,
],

'aliases' => [
    // ...
    'Permission' => SpatiePermissionFacadesPermission::class,
]
Salin selepas log masuk

Akhir sekali, jalankan arahan migrasi pangkalan data untuk mencipta jadual data yang diperlukan:

php artisan migrate
Salin selepas log masuk
  1. Buat model pengguna, peranan dan kebenaran
    Dalam Laravel, tiga model perlu dibuat untuk melaksanakan pengurusan kebenaran: Pengguna (pengguna), Peranan (peranan) dan Kebenaran (kebenaran). Buat model Pengguna di sini dan gunakan pemalam spatie/laravel-permission untuk mengurus peranan dan kebenaran. Jalankan arahan berikut untuk menjana model ini:
php artisan make:model User
php artisan make:model Role
php artisan make:model Permission
Salin selepas log masuk

Kemudian, tambah kod berikut dalam model Pengguna yang dijana:

<?php

namespace App;

use IlluminateNotificationsNotifiable;
use IlluminateFoundationAuthUser as Authenticatable;
use IlluminateDatabaseEloquentRelationsBelongsToMany;
use SpatiePermissionTraitsHasRoles;

class User extends Authenticatable
{
    use Notifiable, HasRoles;

    // ...
}
Salin selepas log masuk
  1. Buat model jabatan dan pekerja
    Untuk melaksanakan struktur organisasi pengguna, anda juga perlu membuat jabatan dan model pekerja. Jalankan arahan berikut untuk menjana model ini:
php artisan make:model Department
php artisan make:model Employee
Salin selepas log masuk

Kemudian, tambah kod berikut dalam model Jabatan:

<?php

namespace App;

use IlluminateDatabaseEloquentModel;
use IlluminateDatabaseEloquentRelationsHasMany;

class Department extends Model
{
    // ...

    public function employees(): HasMany
    {
        return $this->hasMany(Employee::class);
    }
}
Salin selepas log masuk

Tambah kod berikut dalam model Pekerja:

<?php

namespace App;

use IlluminateDatabaseEloquentModel;
use IlluminateDatabaseEloquentRelationsBelongsTo;

class Employee extends Model
{
    // ...

    public function department(): BelongsTo
    {
        return $this->belongsTo(Department::class);
    }
}
Salin selepas log masuk
  1. Tentukan peranan dan kebenaran
    Mengikut keperluan di atas , kita perlu menentukan tiga Peranan: pentadbir jabatan, eksekutif dan pekerja biasa. Cipta jadual peranan dalam pangkalan data, kemudian gunakan perintah migrasi yang disediakan oleh Laravel untuk menjana jadual data peranan:
php artisan make:migration create_roles_table --create=roles
php artisan migrate
Salin selepas log masuk

Jalankan arahan berikut untuk menambah tiga peranan ini:

php artisan permission:create-role department_manager
php artisan permission:create-role executive
php artisan permission:create-role employee
Salin selepas log masuk

Seterusnya, kita juga perlu menentukan beberapa kebenaran . Cipta jadual kebenaran dalam pangkalan data, dan kemudian gunakan arahan migrasi untuk menjana jadual data kebenaran:

php artisan make:migration create_permissions_table --create=permissions
php artisan migrate
Salin selepas log masuk

Jalankan arahan berikut untuk menambah beberapa kebenaran:

php artisan permission:create-permission manage_department
php artisan permission:create-permission manage_employee
Salin selepas log masuk
  1. Tugaskan peranan dan kebenaran
    Untuk melaksanakan kawalan kebenaran, kita perlu menetapkan peranan dan kebenaran kepada pengguna dan jabatan yang sepadan. Berikut ialah beberapa kod sampel:
use AppUser;
use AppRole;
use AppPermission;
use AppDepartment;
use AppEmployee;

// 创建一个部门管理员用户
$user = User::create([
    'name' => '部门管理员',
    'email' => 'manager@example.com',
    'password' => bcrypt('password'),
]);

// 创建一个部门
$department = Department::create([
    'name' => '销售部门',
]);

// 给用户分配部门管理员角色
$user->assignRole('department_manager');

// 将部门管理员角色与权限关联起来
$role = Role::findByName('department_manager');
$role->givePermissionTo('manage_department');

// 将部门管理员与部门关联起来
$employee = Employee::create([
    'name' => '张三',
    'department_id' => $department->id,
]);
Salin selepas log masuk

3. Kod sampel kawalan kebenaran
Setelah kami melengkapkan tetapan asas pengurusan kebenaran, kami boleh mula menyediakan kod kawalan kebenaran. Berikut ialah beberapa contoh kod:

  1. Pentadbir jabatan boleh menguruskan pekerja di bawah jabatan mereka sendiri, tetapi tidak boleh mengakses maklumat daripada jabatan lain.
public function index()
{
    $user = Auth::user();
    $department = $user->employee->department;

    // 部门管理员只能查看本部门的员工列表
    $employees = $department->employees;

    return view('employees.index', compact('employees'));
}
Salin selepas log masuk
  1. Eksekutif boleh mengakses dan mengurus data di seluruh syarikat.
public function index()
{
    $user = Auth::user();

    // 高管可以查看所有部门的员工列表
    $employees = Employee::all();

    return view('employees.index', compact('employees'));
}
Salin selepas log masuk
  1. Pekerja biasa hanya boleh mengakses maklumat peribadi mereka sendiri.
public function show($id)
{
    $user = Auth::user();

    // 普通员工只能查看自己的信息
    $employee = Employee::where('id', $id)
                        ->where('user_id', $user->id)
                        ->firstOrFail();

    return view('employees.show', compact('employee'));
Salin selepas log masuk

Atas ialah kandungan terperinci Aplikasi praktikal fungsi kebenaran Laravel: Cara melaksanakan kawalan kebenaran struktur organisasi pengguna. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan