Rumah >rangka kerja php >Laravel >Panduan Praktikal untuk Fungsi Kebenaran Laravel: Cara Melaksanakan Proses Kelulusan Kebenaran Pengguna

Panduan Praktikal untuk Fungsi Kebenaran Laravel: Cara Melaksanakan Proses Kelulusan Kebenaran Pengguna

王林
王林asal
2023-11-02 12:16:521080semak imbas

Panduan Praktikal untuk Fungsi Kebenaran Laravel: Cara Melaksanakan Proses Kelulusan Kebenaran Pengguna

Panduan praktikal untuk fungsi kebenaran Laravel: Bagaimana untuk melaksanakan proses kelulusan kebenaran pengguna, contoh kod khusus diperlukan

Pengenalan:

Dalam era perkembangan pesat Internet hari ini, pengurusan kebenaran sistem telah menjadi semakin banyak. penting. Sebagai rangka kerja pembangunan PHP yang popular, Laravel menyediakan satu set fungsi pengurusan kebenaran yang mudah dan berkuasa yang boleh membantu pembangun dengan mudah melaksanakan proses kelulusan kebenaran pengguna. Artikel ini akan memperkenalkan cara melaksanakan proses kelulusan kebenaran pengguna dalam rangka kerja Laravel dan memberikan contoh kod khusus.

1. Asas pengurusan kebenaran

Sebelum mula melaksanakan proses kelulusan kebenaran pengguna, kita perlu memahami pengetahuan asas pengurusan kebenaran. Dalam rangka kerja Laravel, pengurusan kebenaran biasanya merangkumi tiga konsep teras: peranan (Peranan), kebenaran (Kebenaran) dan pengguna (Pengguna).

Peranan: Peranan mewakili peranan berbeza yang dimainkan oleh pengguna dalam sistem dan setiap peranan mempunyai kebenaran tertentu.

Kebenaran: Kebenaran mewakili kebenaran pengendalian pengguna dalam sistem, seperti menambah, mengedit, memadam, dsb.

Pengguna: Pengguna ialah individu yang digunakan dalam sistem Setiap pengguna boleh mempunyai satu atau lebih peranan.

Melalui tiga konsep teras ini, kami boleh membina sistem pengurusan hak pengguna yang fleksibel dan berskala.

2. Reka bentuk proses kelulusan kebenaran pengguna

Sebelum melaksanakan proses kelulusan kebenaran pengguna, kami perlu menjelaskan reka bentuk keseluruhan proses. Biasanya, proses kelulusan kebenaran pengguna termasuk langkah berikut:

  1. Pengguna menyerahkan permohonan kebenaran: Pengguna menyerahkan permohonan kebenaran kepada pentadbir sistem, termasuk peranan dan kebenaran yang diperlukan.
  2. Pentadbir meluluskan permohonan kebenaran: Selepas pentadbir menerima permohonan kebenaran pengguna, dia boleh meluluskan permohonan itu.
  3. Berikan kebenaran: Selepas kelulusan, pentadbir boleh menetapkan peranan dan kebenaran yang diperlukan kepada pengguna.
  4. Hadkan kebenaran: Untuk beberapa operasi penting atau maklumat sensitif, pentadbir boleh menetapkan sekatan kebenaran tambahan.

Melalui proses di atas, pengguna boleh memohon kebenaran mengikut keperluan mereka sendiri, dan pentadbir boleh meluluskan permohonan serta memperuntukkan serta menyekat kebenaran mengikut keperluan.

3. Laksanakan proses kelulusan kebenaran pengguna berdasarkan rangka kerja Laravel

Di bawah kami akan melaksanakan proses kelulusan kebenaran pengguna di atas berdasarkan rangka kerja Laravel. Pertama, kita perlu memasang dan mengkonfigurasi rangka kerja Laravel dan mencipta jadual pangkalan data yang diperlukan. Selepas ini, kita boleh mengikuti langkah-langkah di bawah untuk melaksanakannya.

  1. Buat fail pemindahan data

Gunakan fungsi migrasi Laravel untuk mencipta jadual data yang diperlukan, termasuk jadual peranan, jadual kebenaran, jadual pengguna, dsb. Perintah untuk mencipta fail migrasi adalah seperti berikut:

php artisan make:migration create_roles_table
php artisan make:migration create_permissions_table
php artisan make:migration create_users_table

Tentukan medan jadual dalam fail migrasi dan tulis logik migrasi. Contohnya, kod sampel fail pemindahan jadual peranan adalah seperti berikut:

public function up()
{
    Schema::create('roles', function (Blueprint $table) {
        $table->id();
        $table->string('name');
        $table->timestamps();
    });
}

Melaksanakan arahan migrasi akan mencipta jadual data yang sepadan:

php artisan migrate
  1. Buat model dan perhubungan

Buat peranan, kebenaran dan model pengguna mewujudkan hubungan antara mereka hubungan. Dalam rangka kerja Laravel, anda boleh menggunakan persatuan Eloquent untuk menentukan hubungan antara model. Kod sampel adalah seperti berikut:

class Role extends Model
{
    public function permissions()
    {
        return $this->belongsToMany(Permission::class);
    }
}

class Permission extends Model
{
    public function roles()
    {
        return $this->belongsToMany(Role::class);
    }
}

class User extends Authenticatable
{
    public function roles()
    {
        return $this->belongsToMany(Role::class);
    }
}
  1. Laksanakan permohonan kebenaran dan fungsi kelulusan

Tambahkan kaedah berkaitan kelulusan kebenaran dalam model pengguna, termasuk menyerahkan permohonan kebenaran dan meluluskan permohonan kebenaran. Kod sampel adalah seperti berikut:

class User extends Authenticatable
{
    // ...

    public function submitPermissionRequest($roles, $permissions)
    {
        // 创建权限申请记录,并关联角色和权限
        $permissionRequest = PermissionRequest::create([
            'user_id' => $this->id,
            'status' => 'pending',
        ]);
        $permissionRequest->roles()->sync($roles);
        $permissionRequest->permissions()->sync($permissions);
    }

    public function approvePermissionRequest($requestId)
    {
        // 审批权限申请,并分配角色和权限
        $permissionRequest = PermissionRequest::findOrFail($requestId);
        $permissionRequest->update(['status' => 'approved']);
        $this->roles()->sync($permissionRequest->roles);
        $this->permissions()->sync($permissionRequest->permissions);
    }
}
  1. Laksanakan fungsi sekatan kebenaran

Tambah perisian tengah sekatan kebenaran dalam laluan dan pengawal untuk memastikan bahawa hanya pengguna yang mempunyai kebenaran sepadan boleh mengakses halaman tertentu atau melakukan operasi tertentu. Kod sampel adalah seperti berikut:

// 在路由中使用中间件限制权限
Route::middleware('permission:edit')->group(function () {
    Route::get('/edit', 'UserController@edit');
    Route::post('/edit', 'UserController@update');
});

// 在控制器中使用中间件限制权限
public function __construct()
{
    $this->middleware('permission:edit')->only('edit', 'update');
}

Melalui langkah di atas, kami berjaya melaksanakan fungsi proses kelulusan kebenaran pengguna. Pengguna boleh menyerahkan permohonan kebenaran mengikut keperluan, pentadbir boleh meluluskan dan memperuntukkan aplikasi, dan sistem boleh mengehadkan kebenaran pengguna secara automatik.

Kesimpulan:

Melalui pengenalan artikel ini, kami memahami pengetahuan asas pengurusan kebenaran dalam rangka kerja Laravel dan melaksanakan fungsi proses kelulusan kebenaran pengguna. Menggunakan fungsi pengurusan kebenaran yang disediakan oleh rangka kerja Laravel, pembangun boleh membina sistem pengurusan kebenaran yang fleksibel dan mudah diperluaskan dengan cepat. Saya harap artikel ini akan membantu semua orang dalam menggunakan rangka kerja Laravel untuk pengurusan kebenaran.

Rujukan:

  • Dokumentasi rasmi Laravel: https://laravel.com/docs
  • Panduan butiran pengurusan kebenaran Laravel: https://learnku.com/docs/laravel/8.x/authorization/7944
  • Laravel tutorial video pengurusan kebenaran pengguna: https://www.youtube.com/watch?v=GDgrdz2hgJc

Lampiran: Untuk contoh kod lengkap, sila lihat repositori GitHub: https://github.com/example/laravel-permission

Atas ialah kandungan terperinci Panduan Praktikal untuk Fungsi Kebenaran Laravel: Cara Melaksanakan Proses Kelulusan Kebenaran Pengguna. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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