Rumah rangka kerja php Laravel Bagaimana untuk melaksanakan paparan berasaskan kebenaran dan menyembunyikan elemen halaman dalam Laravel

Bagaimana untuk melaksanakan paparan berasaskan kebenaran dan menyembunyikan elemen halaman dalam Laravel

Nov 03, 2023 am 08:35 AM
Kawalan kebenaran Paparan elemen halaman Elemen halaman tersembunyi

Bagaimana untuk melaksanakan paparan berasaskan kebenaran dan menyembunyikan elemen halaman dalam Laravel

Dalam Laravel, adalah keperluan biasa untuk melaksanakan paparan berasaskan kebenaran dan menyembunyikan elemen halaman. Artikel ini akan memperkenalkan cara menggunakan pustaka pengurusan kebenaran Laravel "spatie/laravel-permission" untuk melaksanakan fungsi memaparkan elemen halaman secara dinamik. Pada masa yang sama, untuk menggambarkan masalah dengan lebih baik, artikel ini akan menulis program contoh mudah.

1. Pasang laravel-permission

Mula-mula, anda perlu memasang pakej komposer "spatie/laravel-permission" dalam projek Laravel. Gunakan arahan berikut untuk memasang:

composer require spatie/laravel-permission
Salin selepas log masuk

Selepas pemasangan, anda perlu menjalankan migrasi untuk mencipta jadual pengurusan kebenaran yang berkaitan:

php artisan vendor:publish --provider="SpatiePermissionPermissionServiceProvider" --tag="migrations"

php artisan migrate
Salin selepas log masuk

2. Tentukan peranan dan kebenaran

Dalam contoh ini, kami akan menentukan dua peranan, iaitu "Pengurusan " "Pentadbir" dan "Pengguna Biasa", dan berikan kebenaran pentadbir untuk melihat semua data.

Mula-mula, anda perlu menambah konfigurasi model peranan dan kebenaran dalam fail config/auth.php:

'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => AppModelsUser::class,
    ],

    'roles' => [
        'driver' => 'eloquent',
        'model' => SpatiePermissionModelsRole::class,
    ],

    'permissions' => [
        'driver' => 'eloquent',
        'model' => SpatiePermissionModelsPermission::class,
    ],
],
Salin selepas log masuk

Kemudian, tambahkan perkaitan dengan peranan dan kebenaran dalam model Pengguna:

namespace AppModels;

use IlluminateDatabaseEloquentFactoriesHasFactory;
use IlluminateFoundationAuthUser as Authenticatable;
use SpatiePermissionTraitsHasRoles;

class User extends Authenticatable
{
    use HasFactory, HasRoles;

    //...
}
Salin selepas log masuk

Kemudian anda boleh menentukan peranan dalam Seeder Dan kebenaran:

use IlluminateDatabaseSeeder;
use SpatiePermissionModelsPermission;
use SpatiePermissionModelsRole;

class RolesAndPermissionsSeeder extends Seeder
{
    public function run()
    {
        //创建角色
        Role::create(['name' => 'admin']);
        Role::create(['name' => 'user']);

        //创建权限
        Permission::create(['name' => 'view_all_data']);

        //管理员拥有所有权限
        Role::findByName('admin')->givePermissionTo(Permission::all());
    }
}
Salin selepas log masuk

3. Keizinan dan pengesahan

Seterusnya, gunakan kaedah authorize() dalam pengawal untuk menentukan sama ada pengguna mempunyai kebenaran khusus. Sebagai contoh, kaedah indeks berikut memerlukan kebenaran "view_all_data":

public function index()
{
    $this->authorize('view_all_data');
    //...
}
Salin selepas log masuk

Selain itu, dalam paparan, anda boleh menggunakan kaedah can() untuk menentukan sama ada pengguna semasa mempunyai kebenaran tertentu. Contohnya, dalam kod berikut, butang "Lihat Semua Data" akan dipaparkan hanya jika pengguna mempunyai kebenaran "lihat_semua_data":

@if(auth()->user()->can('view_all_data'))
    <button>查看所有数据</button>
@endif
Salin selepas log masuk

Jika anda mahukan kawalan yang lebih terperinci, anda boleh menggunakan kaedah role() untuk menentukan sama ada pengguna mempunyai peranan tertentu. Contohnya, dalam kod berikut, "Menu Pentadbir" akan dipaparkan hanya apabila pengguna mempunyai peranan "pentadbir":

@if(auth()->user()->hasRole('admin'))
    <menu>管理员菜单</menu>
@endif
Salin selepas log masuk

4. Penyampaian dinamik elemen halaman

Kadangkala, beberapa elemen dalam halaman perlu berdasarkan pada Peranan atau kebenaran pengguna semasa untuk dipaparkan secara dinamik. Sebagai contoh, anda boleh menetapkan bahawa hanya pentadbir boleh melihat butang "Padam":

@if(auth()->user()->can('delete_data'))
    <button>删除</button>
@endif
Salin selepas log masuk

Walau bagaimanapun, jika terdapat berbilang elemen yang perlu dipaparkan secara dinamik berdasarkan kebenaran, maka setiap elemen mesti dinilai secara individu, yang akan membawa kepada kod pertindihan dan peningkatan kos penyelenggaraan. Pada masa ini, anda boleh merangkum fungsi ini ke dalam arahan Blade dan biarkan ia menerima nama kebenaran sebagai parameter:

Blade::directive('can', function ($expression) {
    return "<?php if(auth()->user()->can({$expression})): ?>";
});

Blade::directive('endcan', function () {
    return "<?php endif; ?>";
});
Salin selepas log masuk

Menggunakan arahan ini, anda boleh memaparkan elemen halaman secara dinamik dengan cara berikut:

@can('delete_data')
    <button>删除</button>
@endcan
Salin selepas log masuk

Dengan cara ini, kod menjadi Lebih ringkas dan jelas.

Ringkasan

Dengan menggunakan perpustakaan pengurusan kebenaran Laravel "spatie/laravel-permission", kami boleh melaksanakan paparan berasaskan kebenaran dan menyembunyikan elemen halaman dengan mudah. Pada masa yang sama, merangkum kod yang dihasilkan secara dinamik ke dalam arahan Blade boleh memudahkan lagi kod dan meningkatkan kebolehbacaan dan kebolehselenggaraan kod.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan paparan berasaskan kebenaran dan menyembunyikan elemen halaman 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
3 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)

Cara melaksanakan kawalan kebenaran dan pengurusan pengguna dalam uniapp Cara melaksanakan kawalan kebenaran dan pengurusan pengguna dalam uniapp Oct 20, 2023 am 11:15 AM

Bagaimana untuk melaksanakan kawalan kebenaran dan pengurusan pengguna dalam uniapp Dengan pembangunan aplikasi mudah alih, kawalan kebenaran dan pengurusan pengguna telah menjadi bahagian penting dalam pembangunan aplikasi. Dalam uniapp, kami boleh menggunakan beberapa kaedah praktikal untuk melaksanakan kedua-dua fungsi ini dan meningkatkan keselamatan dan pengalaman pengguna aplikasi. Artikel ini akan memperkenalkan cara untuk melaksanakan kawalan kebenaran dan pengurusan pengguna dalam uniapp, dan menyediakan beberapa contoh kod khusus untuk rujukan. 1. Kawalan Kebenaran Kawalan kebenaran merujuk kepada menetapkan kebenaran pengendalian yang berbeza untuk pengguna atau kumpulan pengguna yang berbeza dalam aplikasi untuk melindungi aplikasi.

Melaksanakan kebenaran pengguna dan kawalan akses menggunakan PHP dan SQLite Melaksanakan kebenaran pengguna dan kawalan akses menggunakan PHP dan SQLite Jul 29, 2023 pm 02:33 PM

Melaksanakan kebenaran pengguna dan kawalan akses menggunakan PHP dan SQLite Dalam aplikasi web moden, kebenaran pengguna dan kawalan akses adalah bahagian yang sangat penting. Dengan pengurusan kebenaran yang betul, anda boleh memastikan bahawa hanya pengguna yang diberi kuasa boleh mengakses halaman dan fungsi tertentu. Dalam artikel ini, kita akan belajar cara melaksanakan kebenaran pengguna asas dan kawalan akses menggunakan PHP dan SQLite. Pertama, kita perlu mencipta pangkalan data SQLite untuk menyimpan maklumat tentang pengguna dan kebenaran mereka. Berikut ialah struktur jadual pengguna ringkas dan jadual kebenaran

Pengurusan pengguna dan kawalan kebenaran dalam Laravel: melaksanakan berbilang pengguna dan tugasan peranan Pengurusan pengguna dan kawalan kebenaran dalam Laravel: melaksanakan berbilang pengguna dan tugasan peranan Aug 12, 2023 pm 02:57 PM

Pengurusan pengguna dan kawalan kebenaran dalam Laravel: Melaksanakan tugasan berbilang pengguna dan peranan Pengenalan: Dalam aplikasi web moden, pengurusan pengguna dan kawalan kebenaran adalah salah satu fungsi yang sangat penting. Laravel, sebagai rangka kerja PHP yang popular, menyediakan alatan yang berkuasa dan fleksibel untuk melaksanakan kawalan kebenaran untuk berbilang pengguna dan tugasan peranan. Artikel ini akan memperkenalkan cara melaksanakan pengurusan pengguna dan fungsi kawalan kebenaran dalam Laravel, dan menyediakan contoh kod yang berkaitan. 1. Pemasangan dan konfigurasi Mula-mula, laksanakan pengurusan pengguna dalam Laravel

Amalan Terbaik untuk Ciri Keizinan Laravel: Cara Mengawal Kebenaran Pengguna dengan Betul Amalan Terbaik untuk Ciri Keizinan Laravel: Cara Mengawal Kebenaran Pengguna dengan Betul Nov 02, 2023 pm 12:32 PM

Amalan terbaik untuk fungsi kebenaran Laravel: Cara mengawal kebenaran pengguna dengan betul memerlukan contoh kod khusus Pengenalan: Laravel ialah rangka kerja PHP yang sangat berkuasa dan popular yang menyediakan banyak fungsi dan alatan untuk membantu kami membangunkan aplikasi web yang cekap dan selamat. Satu ciri penting ialah kawalan kebenaran, yang menyekat akses pengguna ke bahagian aplikasi yang berbeza berdasarkan peranan dan kebenaran mereka. Kawalan kebenaran yang betul ialah komponen utama mana-mana aplikasi web untuk melindungi data dan fungsi sensitif daripada capaian yang tidak dibenarkan

Bagaimana untuk melaksanakan log masuk pengguna dan kawalan kebenaran dalam PHP? Bagaimana untuk melaksanakan log masuk pengguna dan kawalan kebenaran dalam PHP? Jun 29, 2023 pm 02:28 PM

Bagaimana untuk melaksanakan log masuk pengguna dan kawalan kebenaran dalam PHP? Apabila membangunkan aplikasi web, log masuk pengguna dan kawalan kebenaran adalah salah satu fungsi yang sangat penting. Melalui log masuk pengguna, kami boleh mengesahkan pengguna dan melaksanakan satu siri kawalan operasi berdasarkan kebenaran pengguna. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan log masuk pengguna dan fungsi kawalan kebenaran. 1. Fungsi log masuk pengguna Melaksanakan fungsi log masuk pengguna ialah langkah pertama dalam pengesahan pengguna Hanya pengguna yang telah lulus pengesahan boleh melakukan operasi selanjutnya. Berikut ialah proses pelaksanaan log masuk pengguna asas: Cipta

Cara menggunakan ACL (Senarai Kawalan Akses) untuk kawalan kebenaran dalam Rangka Kerja Zend Cara menggunakan ACL (Senarai Kawalan Akses) untuk kawalan kebenaran dalam Rangka Kerja Zend Jul 29, 2023 am 09:24 AM

Cara menggunakan ACL (AccessControlList) untuk kawalan kebenaran dalam Rangka Kerja Zend Pengenalan: Dalam aplikasi web, kawalan kebenaran ialah fungsi penting. Ia memastikan bahawa pengguna hanya boleh mengakses halaman dan ciri yang dibenarkan untuk mereka akses dan menghalang akses yang tidak dibenarkan. Rangka kerja Zend menyediakan cara yang mudah untuk melaksanakan kawalan kebenaran, menggunakan komponen ACL (AccessControlList). Artikel ini akan memperkenalkan cara menggunakan ACL dalam Rangka Kerja Zend

Kemahiran pembangunan Vue: melaksanakan penghalaan dinamik dan kawalan kebenaran Kemahiran pembangunan Vue: melaksanakan penghalaan dinamik dan kawalan kebenaran Nov 02, 2023 pm 12:12 PM

Kemahiran pembangunan Vue: Melaksanakan penghalaan dinamik dan kawalan kebenaran Pengenalan: Dalam aplikasi web moden, penghalaan dinamik dan kawalan kebenaran adalah fungsi penting. Untuk aplikasi yang besar, pelaksanaan kedua-dua fungsi ini boleh meningkatkan pengalaman dan keselamatan pengguna dengan ketara. Artikel ini akan memperkenalkan cara menggunakan rangka kerja Vue untuk melaksanakan teknik pembangunan untuk penghalaan dinamik dan kawalan kebenaran. Kami akan menggambarkan aplikasi khusus teknik ini dengan contoh. 1. Penghalaan dinamik Penghalaan dinamik merujuk kepada mencipta dan menghuraikan laluan secara dinamik berdasarkan peranan pengguna atau keadaan lain semasa aplikasi berjalan. lulus

Cara menggunakan kawalan kebenaran dan pengesahan dalam C# Cara menggunakan kawalan kebenaran dan pengesahan dalam C# Oct 09, 2023 am 11:01 AM

Cara menggunakan kawalan kebenaran dan pengesahan dalam C# memerlukan contoh kod khusus Dalam era Internet hari ini, isu keselamatan maklumat telah mendapat perhatian yang semakin meningkat. Untuk melindungi keselamatan sistem dan data, kawalan kebenaran dan pengesahan telah menjadi bahagian yang sangat diperlukan untuk pembangun. Sebagai bahasa pengaturcaraan yang biasa digunakan, C# menyediakan pelbagai fungsi dan perpustakaan kelas untuk membantu kami melaksanakan kawalan kebenaran dan pengesahan. Kawalan kebenaran merujuk kepada menyekat akses pengguna kepada sumber tertentu berdasarkan identiti pengguna, peranan, kebenaran, dsb. Cara biasa untuk melaksanakan kawalan kebenaran adalah dengan

See all articles