Rumah rangka kerja php Laravel Bagaimana untuk melaksanakan sistem pengurusan kebenaran dalam Laravel

Bagaimana untuk melaksanakan sistem pengurusan kebenaran dalam Laravel

Nov 02, 2023 pm 04:51 PM
laravel Pelaksanaan sistem Pengurusan kebenaran

Bagaimana untuk melaksanakan sistem pengurusan kebenaran dalam Laravel

Cara melaksanakan sistem pengurusan kebenaran dalam Laravel

Pengenalan:
Dengan pembangunan aplikasi web yang berterusan, sistem pengurusan kebenaran telah menjadi salah satu fungsi asas bagi banyak aplikasi. Laravel, sebagai rangka kerja PHP yang popular, menyediakan pelbagai alatan dan fungsi untuk melaksanakan sistem pengurusan kebenaran. Artikel ini akan memperkenalkan cara untuk melaksanakan sistem pengurusan kebenaran yang mudah dan berkuasa dalam Laravel dan memberikan contoh kod khusus.

1. Idea Reka Bentuk Sistem Pengurusan Kebenaran
Apabila mereka bentuk sistem pengurusan kebenaran, anda perlu mempertimbangkan perkara penting berikut:

  1. Definisi peranan dan kebenaran: Peranan merujuk kepada fungsi atau identiti pengguna, dan kebenaran merujuk kepada kawalan pengguna ke atas sistem Akses kepada fungsi atau sumber.
  2. Hubungan antara pengguna dan peranan: Pengguna boleh mempunyai berbilang peranan dan peranan boleh dimiliki oleh berbilang pengguna.
  3. Hubungan antara kebenaran dan peranan: Peranan boleh mempunyai berbilang kebenaran dan satu kebenaran boleh dimiliki oleh berbilang peranan.
  4. Hubungan antara penghalaan dan kebenaran: Penghalaan menentukan laluan masuk untuk pengguna mengakses fungsi sistem. Laluan yang berbeza mungkin memerlukan kebenaran yang berbeza untuk menyekat akses.

Berdasarkan idea reka bentuk di atas, kita boleh mula melaksanakan sistem pengurusan kebenaran dalam Laravel.

2. Reka bentuk dan migrasi pangkalan data
Dalam Laravel, kami boleh menggunakan migrasi pangkalan data untuk mencipta dan mengubah suai jadual pangkalan data. Berikut ialah reka bentuk pangkalan data yang ringkas:

  1. Jadual pengguna (pengguna): menyimpan maklumat asas pengguna, seperti nama pengguna, kata laluan, dsb.
  2. Jadual peranan (peranan): Menyimpan maklumat asas peranan, seperti nama peranan, perihalan, dsb.
  3. Jadual kebenaran: menyimpan maklumat asas tentang kebenaran, seperti nama kebenaran, perihalan, dsb.
  4. Jadual persatuan kebenaran peranan (permission_permission): merekodkan hubungan yang sepadan antara peranan dan kebenaran.
  5. Jadual perkaitan peranan pengguna (peranan_pengguna): merekodkan perhubungan yang sepadan antara pengguna dan peranan.

Mula-mula, buat fail migrasi:

php artisan make:migration create_users_table
php artisan make:migration create_roles_table
php artisan make:migration create_permissions_table
php artisan make:migration create_role_permission_table
php artisan make:migration create_user_role_table
Salin selepas log masuk

Kemudian, tulis struktur jadual dalam fail migrasi yang sepadan (kod ditinggalkan), dan jalankan arahan migrasi:

php artisan migrate
Salin selepas log masuk

Tiga Tentukan hubungan model
Dalam Laravel. kami Anda boleh menggunakan model Eloquent untuk menentukan hubungan antara jadual pangkalan data. Pertama, kita perlu menentukan tiga model: Pengguna, Peranan dan Kebenaran.

  1. Model pengguna (Pengguna)

    namespace App;
    
    use IlluminateDatabaseEloquentModel;
    
    class User extends Model
    {
     // 用户与角色的多对多关系
     public function roles()
     {
         return $this->belongsToMany('AppRole')->withTimestamps();
     }
    
     // 判断用户是否拥有某个角色
     public function hasRole($role)
     {
         if (is_string($role)) {
             return $this->roles->contains('name', $role);
         }
    
         return !! $role->intersect($this->roles)->count();
     }
    
     // 判断用户是否拥有某个权限
     public function hasPermission($permission)
     {
         return $this->hasRole($permission->roles);
     }
    }
    Salin selepas log masuk
  2. Role model (Role)

    namespace App;
    
    use IlluminateDatabaseEloquentModel;
    
    class Role extends Model
    {
     // 角色与用户的多对多关系
     public function users()
     {
         return $this->belongsToMany('AppUser')->withTimestamps();
     }
    
     // 角色与权限的多对多关系
     public function permissions()
     {
         return $this->belongsToMany('AppPermission')->withTimestamps();
     }
    
     // 判断角色是否拥有某个权限
     public function hasPermission($permission)
     {
         if (is_string($permission)) {
             return $this->permissions->contains('name', $permission);
         }
    
         return !! $permission->intersect($this->permissions)->count();
     }
    }
    Salin selepas log masuk
  3. Model kebenaran (Kebenaran)

    namespace App;
    
    use IlluminateDatabaseEloquentModel;
    
    class Permission extends Model
    {
     // 权限与角色的多对多关系
     public function roles()
     {
         return $this->belongsToMany('AppRole');
     }
    }
    Salin selepas log masuk
kita boleh Gunakan middleware untuk memintas dan mengesahkan permintaan akses pengguna. Pertama, kita perlu menentukan perisian tengah kebenaran.


    Takrifkan middleware kebenaran:
  1. namespace AppHttpMiddleware;
    
    use Closure;
    use IlluminateSupportFacadesAuth;
    
    class CheckPermission
    {
     public function handle($request, Closure $next, $permission)
     {
         $user = Auth::user();
         
         if ($user && $user->hasPermission($permission)) {
             return $next($request);
         }
         
         return redirect()->route('403'); // 没有权限则跳转到403页面
     }
    }
    Salin selepas log masuk

  2. Daftar perisian tengah kebenaran:
  3. Daftar perisian tengah kebenaran dalam tatasusunan $routeMiddleware dalam appHttpKernel.php

    reeee:
    Kaitkan middleware dan penghalaan: appHttpKernel.php中的$routeMiddleware数组中注册权限中间件:

    protected $routeMiddleware = [
     // ...
     'permission' => AppHttpMiddlewareCheckPermission::class,
    ];
    Salin selepas log masuk
  4. 关联中间件与路由:
    routesweb.php中定义需要权限控制的路由,并使用permissionTentukan laluan yang memerlukan kawalan kebenaran dalam routesweb.php dan gunakan permission middleware:

    Route::get('/members', 'MemberController@index')->middleware('permission:member_view');
    Salin selepas log masuk

5. anda boleh menggunakan contoh kod berikut untuk mengesahkan identiti pengguna dan mengembalikan paparan yang sepadan berdasarkan kebenaran.

  1. Kaedah dalam pengawal:

    namespace AppHttpControllers;
    
    use IlluminateSupportFacadesAuth;
    
    class MemberController extends Controller
    {
     public function index()
     {
        if (Auth::user()->hasPermission('member_view')) {
             return view('members.index');
        }
        
        // 没有权限则跳转到403页面
        return redirect()->route('403');
     }
    }
    Salin selepas log masuk

  2. Kod dalam paparan:

    @if(Auth::user()->hasPermission('member_view'))
     <!-- 具有查看成员的权限,显示相关内容 -->
     <table>
         ...
     </table>
    @else
     <!-- 没有权限,显示无权限提示 -->
     <div>您没有查看成员的权限</div>
    @endif
    Salin selepas log masuk
    6. Ringkasan

    Melalui langkah di atas, kami berjaya melaksanakan sistem pengurusan kebenaran yang mudah dan berkuasa dalam Laravel Dengan mentakrifkan peranan, kebenaran dan perhubungan yang sepadan, menggunakan perisian tengah untuk memintas laluan, dan menilai kebenaran dalam pengawal dan pandangan, kami boleh mencapai kawalan yang tepat ke atas kebenaran akses pengguna. Saya harap artikel ini dapat membantu anda lebih memahami dan menggunakan fungsi pengurusan kebenaran dalam Laravel.

    Rujukan:

      Dokumentasi rasmi Laravel (https://laravel.com/docs/8.x/)
    • Tutorial siri Laravel Beyond CRUD: Pengurusan kebenaran (https://laravelbestpractices.com/series/show/ laravel -beyond-crud/episod/9)

    Atas ialah kandungan terperinci Bagaimana untuk melaksanakan sistem pengurusan kebenaran dalam Laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana untuk menggunakan pemetaan hubungan objek (ORM) dalam PHP untuk memudahkan operasi pangkalan data? Bagaimana untuk menggunakan pemetaan hubungan objek (ORM) dalam PHP untuk memudahkan operasi pangkalan data? May 07, 2024 am 08:39 AM

Operasi pangkalan data dalam PHP dipermudahkan menggunakan ORM, yang memetakan objek ke dalam pangkalan data hubungan. EloquentORM dalam Laravel membolehkan anda berinteraksi dengan pangkalan data menggunakan sintaks berorientasikan objek Anda boleh menggunakan ORM dengan mentakrifkan kelas model, menggunakan kaedah Eloquent atau membina sistem blog dalam amalan.

Perbandingan versi terkini Laravel dan CodeIgniter Perbandingan versi terkini Laravel dan CodeIgniter Jun 05, 2024 pm 05:29 PM

Versi terkini Laravel 9 dan CodeIgniter 4 menyediakan ciri dan penambahbaikan yang dikemas kini. Laravel9 menggunakan seni bina MVC dan menyediakan fungsi seperti migrasi pangkalan data, pengesahan dan enjin templat. CodeIgniter4 menggunakan seni bina HMVC untuk menyediakan penghalaan, ORM dan caching. Dari segi prestasi, corak reka bentuk berasaskan pembekal perkhidmatan Laravel9 dan rangka kerja ringan CodeIgniter4 memberikannya prestasi cemerlang. Dalam aplikasi praktikal, Laravel9 sesuai untuk projek kompleks yang memerlukan fleksibiliti dan fungsi berkuasa, manakala CodeIgniter4 sesuai untuk pembangunan pesat dan aplikasi kecil.

Bagaimanakah keupayaan pemprosesan data dalam Laravel dan CodeIgniter dibandingkan? Bagaimanakah keupayaan pemprosesan data dalam Laravel dan CodeIgniter dibandingkan? Jun 01, 2024 pm 01:34 PM

Bandingkan keupayaan pemprosesan data Laravel dan CodeIgniter: ORM: Laravel menggunakan EloquentORM, yang menyediakan pemetaan hubungan kelas-objek, manakala CodeIgniter menggunakan ActiveRecord untuk mewakili model pangkalan data sebagai subkelas kelas PHP. Pembina pertanyaan: Laravel mempunyai API pertanyaan berantai yang fleksibel, manakala pembina pertanyaan CodeIgniter lebih ringkas dan berasaskan tatasusunan. Pengesahan data: Laravel menyediakan kelas Pengesah yang menyokong peraturan pengesahan tersuai, manakala CodeIgniter mempunyai kurang fungsi pengesahan terbina dalam dan memerlukan pengekodan manual peraturan tersuai. Kes praktikal: Contoh pendaftaran pengguna menunjukkan Lar

Laravel - Perintah Artisan Laravel - Perintah Artisan Aug 27, 2024 am 10:51 AM

Laravel - Perintah Artisan - Laravel 5.7 hadir dengan cara baharu untuk merawat dan menguji arahan baharu. Ia termasuk ciri baharu untuk menguji arahan artisan dan demonstrasi disebut di bawah?

Mana satu yang lebih mesra pemula, Laravel atau CodeIgniter? Mana satu yang lebih mesra pemula, Laravel atau CodeIgniter? Jun 05, 2024 pm 07:50 PM

Untuk pemula, CodeIgniter mempunyai keluk pembelajaran yang lebih lembut dan ciri yang lebih sedikit, tetapi meliputi keperluan asas. Laravel menawarkan set ciri yang lebih luas tetapi mempunyai keluk pembelajaran yang lebih curam. Dari segi prestasi, kedua-dua Laravel dan CodeIgniter berprestasi baik. Laravel mempunyai dokumentasi yang lebih luas dan sokongan komuniti yang aktif, manakala CodeIgniter lebih ringkas, ringan dan mempunyai ciri keselamatan yang kukuh. Dalam kes praktikal membina aplikasi blog, EloquentORM Laravel memudahkan manipulasi data, manakala CodeIgniter memerlukan lebih banyak konfigurasi manual.

Laravel vs CodeIgniter: Rangka kerja manakah yang lebih baik untuk projek besar? Laravel vs CodeIgniter: Rangka kerja manakah yang lebih baik untuk projek besar? Jun 04, 2024 am 09:09 AM

Apabila memilih rangka kerja untuk projek besar, Laravel dan CodeIgniter masing-masing mempunyai kelebihan mereka sendiri. Laravel direka untuk aplikasi peringkat perusahaan, menawarkan reka bentuk modular, suntikan pergantungan dan set ciri yang berkuasa. CodeIgniter ialah rangka kerja ringan yang lebih sesuai untuk projek kecil hingga sederhana, menekankan kelajuan dan kemudahan penggunaan. Untuk projek besar dengan keperluan yang kompleks dan bilangan pengguna yang ramai, kuasa dan kebolehskalaan Laravel adalah lebih sesuai. Untuk projek atau situasi mudah dengan sumber terhad, keupayaan pembangunan CodeIgniter yang ringan dan pantas adalah lebih ideal.

Soalan dan Jawapan mengenai Reka Bentuk Seni Bina Perkhidmatan Mikro Aplikasi PHP Enterprise Soalan dan Jawapan mengenai Reka Bentuk Seni Bina Perkhidmatan Mikro Aplikasi PHP Enterprise May 07, 2024 am 09:36 AM

Seni bina perkhidmatan mikro menggunakan rangka kerja PHP (seperti Symfony dan Laravel) untuk melaksanakan perkhidmatan mikro dan mengikut prinsip RESTful dan format data standard untuk mereka bentuk API. Perkhidmatan mikro berkomunikasi melalui baris gilir mesej, permintaan HTTP atau gRPC dan menggunakan alatan seperti Prometheus dan ELKStack untuk pemantauan dan penyelesaian masalah.

Laravel vs CodeIgniter: Rangka kerja manakah yang lebih baik untuk projek kecil? Laravel vs CodeIgniter: Rangka kerja manakah yang lebih baik untuk projek kecil? Jun 04, 2024 pm 05:29 PM

Untuk projek kecil, Laravel sesuai untuk projek yang lebih besar yang memerlukan fungsi dan keselamatan yang kukuh. CodeIgniter sesuai untuk projek yang sangat kecil yang memerlukan ringan dan mudah digunakan.

See all articles