Rumah > rangka kerja php > Laravel > Penggunaan cekap fungsi kebenaran Laravel: Cara mereka bentuk sistem kebenaran yang fleksibel dan berskala

Penggunaan cekap fungsi kebenaran Laravel: Cara mereka bentuk sistem kebenaran yang fleksibel dan berskala

WBOY
Lepaskan: 2023-11-03 19:06:26
asal
1155 orang telah melayarinya

Penggunaan cekap fungsi kebenaran Laravel: Cara mereka bentuk sistem kebenaran yang fleksibel dan berskala

Penggunaan fungsi kebenaran Laravel yang cekap: Cara mereka bentuk sistem kebenaran yang fleksibel dan berskala, contoh kod khusus diperlukan

Pengenalan:
Pengurusan kebenaran pengguna ialah ciri penting dan biasa apabila membangunkan aplikasi web. Sebagai rangka kerja PHP yang popular, Laravel menyediakan fungsi pengurusan kebenaran yang berkuasa, yang boleh membantu kami melaksanakan kawalan kebenaran pengguna dengan mudah. Artikel ini akan memperkenalkan cara mereka bentuk sistem kebenaran yang fleksibel dan berskala serta cara menggunakan fungsi kebenaran dengan cekap dalam rangka kerja Laravel.

1. Reka bentuk kebenaran:
Sebelum mula melaksanakan fungsi kebenaran, anda perlu mereka bentuk struktur jadual kebenaran. Secara umumnya, sistem kebenaran melibatkan tiga konsep teras: Pengguna, Peranan dan Kebenaran.

  1. Pengguna: Pengguna berdaftar dalam sistem mungkin mempunyai peranan atau kebenaran yang berbeza.
  2. Peranan: Peranan mewakili satu set kebenaran Pengguna diberikan peranan yang berbeza untuk mengawal kebenaran mereka.
  3. Kebenaran: Mewakili operasi atau sumber tertentu, yang boleh menjadi URL, elemen halaman atau modul berfungsi. Setiap kebenaran boleh diberikan kepada satu atau lebih peranan atau pengguna.

Berdasarkan konsep di atas, kami boleh mereka bentuk struktur jadual data berikut:

  1. jadual pengguna:

    • id: ID pengguna
    • nama: nama pengguna
  2. jadual pengguna:

    • id: ID pengguna
    • nama: nama pengguna
    • : ID peranan
  3. nama: nama peranan
    • jadual kebenaran:
    • id: ID kebenaran
  4. nama: nama kebenaran
    • role_id
    • jadual pengguna: ID_role_
    • :
    • id_pengguna: ID pengguna


permission_role table:

  1. permission_id: kebenaran ID

    role_id: role ID
  2. 2. Perlaksanaan fungsi Laravel: Laravel menggunakan Pakej sambungan kebenaran Laravel ( Seperti Spatie Laravel Permissions) untuk dilaksanakan dengan cepat. Di bawah ialah beberapa contoh kod untuk menunjukkan cara membuat dan mengurus kebenaran dalam Laravel.
  3. Pasang pek sambungan:
  4. composer require spatie/laravel-permission
    Salin selepas log masuk
  5. Buat model kebenaran:
  6. php artisan make:model Permission -m
    Salin selepas log masuk
  7. Tambah medan dalam fail migrasi jadual kebenaran:
  8. $table->string('name');
    $table->timestamps();
    Salin selepas log masuk
    Salin selepas log masuk
    Salin selepas log masuk
    model peranan dan model peranan pengguna
  9. php artisan make:model Role -m
    php artisan make:model RoleUser -m
    Salin selepas log masuk

    reee
  10. Tambah medan dalam jadual peranan dan fail migrasi jadual role_user:

    $table->string('name');
    $table->timestamps();
    Salin selepas log masuk
    Salin selepas log masuk
    Salin selepas log masuk
  11. Buat model pengguna dan model perkaitan peranan pengguna:

    php artisan make:model User -m
    php artisan make:model UserRole -m
    Salin selepas log masuk
  12. Tambah medan dalam jadual pengguna dan fail migrasi jadual pengguna_role:

    $table->string('name');
    $table->timestamps();
    Salin selepas log masuk
    Salin selepas log masuk
    Salin selepas log masuk
  13. Ree Migrasi pangkalan data:

    php artisan migrate
    Salin selepas log masuk

  14. Ciri menggunakan Kebenaran Laravel dalam model Pengguna:

    use SpatiePermissionTraitsHasRoles;
    class User extends Authenticatable
    {
        use Notifiable, HasRoles;
        // 其他代码...
    }
    Salin selepas log masuk

Buat laluan untuk menunjukkan kawalan kebenaran:

Route::get('/admin', function () {
    // 检查用户是否具有 "管理权限"
    if (auth()->user()->hasPermissionTo('manage')) {
        return view('admin.dashboard');
    } else {
        abort(403, '你没有权限访问该页面!');
    }
});
Salin selepas log masuk

🎜🎜🎜🎜Buat peranan dan kebenaran🎜🎜 s kepada Peranan dan Pengguna: 🎜
$role = Role::create(['name' => 'admin']);
$permission = Permission::create(['name' => 'manage']);
Salin selepas log masuk
🎜🎜🎜Kesimpulan: 🎜Dengan langkah di atas, kami boleh melaksanakan sistem kebenaran yang mudah tetapi fleksibel dan boleh diperluaskan dalam rangka kerja Laravel. Menggunakan pakej sambungan kebenaran Laravel, kami boleh mengurus perkaitan antara peranan dan kebenaran pengguna dengan mudah, serta melaksanakan kawalan kebenaran. Pembangun boleh mengembangkan dan menyesuaikannya mengikut keperluan khusus untuk memenuhi keperluan pengurusan kebenaran bagi projek yang berbeza. 🎜

Atas ialah kandungan terperinci Penggunaan cekap fungsi kebenaran Laravel: Cara mereka bentuk sistem kebenaran yang fleksibel dan berskala. 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