Rumah rangka kerja php Laravel Penggunaan lanjutan fungsi kebenaran Laravel: Cara melaksanakan peruntukan kebenaran dinamik

Penggunaan lanjutan fungsi kebenaran Laravel: Cara melaksanakan peruntukan kebenaran dinamik

Nov 02, 2023 pm 03:23 PM
laravel + kebenaran dinamik + penggunaan lanjutan

Penggunaan lanjutan fungsi kebenaran Laravel: Cara melaksanakan peruntukan kebenaran dinamik

Penggunaan lanjutan fungsi kebenaran Laravel: Cara melaksanakan peruntukan kebenaran dinamik

Laravel ialah rangka kerja pembangunan PHP yang sangat popular Ia menyepadukan fungsi pengurusan kebenaran yang berkuasa, yang boleh membantu kami mengawal akses pengguna kepada pelbagai aspek sistem secara fleksibel. . Kebenaran akses untuk modul fungsi. Artikel ini akan memperkenalkan penggunaan lanjutan fungsi kebenaran dalam Laravel, memfokuskan pada cara melaksanakan peruntukan kebenaran dinamik dan menyediakan contoh kod khusus.

1. Kawalan kebenaran asas

Sebelum kita mula menerangkan peruntukan kebenaran dinamik, mari kita semak semula kawalan kebenaran asas dalam Laravel. Laravel menyediakan fasad pengurusan kebenaran yang dipanggil "Gate" yang melaluinya kami boleh menentukan dan menyemak kebenaran.

1.1 Tentukan kebenaran

Pertama, kita perlu menentukan satu siri kebenaran dalam Laravel. Dalam kaedah "boot" dalam fail app/Providers/AuthServiceProvider.php, anda boleh menggunakan kaedah "define" fasad Gate untuk menentukan kebenaran. Contohnya:

public function boot()
{
    $this->registerPolicies();

    Gate::define('view-admin', function ($user) {
        return $user->hasRole('admin');
    });

    Gate::define('edit-post', function ($user, $post) {
        return $user->id === $post->user_id;
    });
}
Salin selepas log masuk

Dalam contoh di atas, "view-admin" dan "edit-post" masing-masing ialah nama dua kebenaran, dan logik kebenaran yang sepadan dilaksanakan melalui fungsi tanpa nama. Kebenaran pertama menyemak sama ada pengguna mempunyai peranan "pentadbir", dan kebenaran kedua menyemak sama ada pengguna adalah pengarang artikel.

1.2 Semak kebenaran

Di mana kita perlu mengawal kebenaran, kita boleh menggunakan kaedah "membolehkan" atau "menolak" fasad "Gate" untuk menyemak kebenaran. Contohnya, dalam kaedah pengawal:

public function edit($id)
{
    $post = Post::find($id);

    if (Gate::denies('edit-post', $post)) {
        abort(403, '无权编辑该文章');
    }

    // 继续执行其他操作
}
Salin selepas log masuk

Dalam contoh di atas, jika pengguna tidak mempunyai kebenaran "edit-post", halaman ralat 403 akan dikembalikan.

2. Peruntukan kebenaran dinamik

Peruntukan kebenaran dinamik merujuk kepada menentukan sama ada pengguna mempunyai kebenaran khusus berdasarkan beberapa keadaan dinamik. Dalam sesetengah senario yang kompleks, definisi kebenaran statik sahaja tidak dapat memenuhi keperluan Dalam kes ini, peruntukan kebenaran dinamik perlu digunakan.

2.1 Menggunakan kelas dasar

Laravel menyediakan mekanisme yang dipanggil kelas dasar Melalui kelas dasar, kami boleh menentukan sama ada pengguna mempunyai kebenaran yang sepadan berdasarkan syarat yang berbeza. Mula-mula, kita perlu membuat kelas dasar dalam direktori aplikasi/Dasar, seperti PostPolicy.php:

<?php

namespace AppPolicies;

use AppModelsUser;
use AppModelsPost;

class PostPolicy
{
    public function edit(User $user, Post $post)
    {
        return $user->id === $post->user_id;
    }
}
Salin selepas log masuk

Dalam contoh di atas, kami menentukan kaedah bernama "edit", yang digunakan untuk menyemak sama ada pengguna mempunyai kebenaran untuk edit artikel.

2.2 Daftar kelas dasar

Seterusnya, kita perlu mendaftar kelas dasar dalam fail app/Providers/AuthServiceProvider.php. Dalam kaedah "boot", tambah kod berikut:

public function boot()
{
    $this->registerPolicies();

    Gate::resource('post', 'AppPoliciesPostPolicy');
}
Salin selepas log masuk

Dalam contoh di atas, kami menggunakan kaedah "Gate::resource" untuk mendaftar secara automatik kelas dasar sumber yang sepadan. Parameter "post" ialah nama sumber dan "AppPoliciesPostPolicy" ialah ruang nama kelas dasar.

2.3 Menggunakan Kelas Strategi

Apabila menggunakan fasad "Gate" untuk menyemak kebenaran dalam pengawal atau di tempat lain, anda boleh menggantikan nama kebenaran dengan nama kaedah yang sepadan dalam kelas strategi. Ambil penyuntingan artikel sebagai contoh:

public function edit($id)
{
    $post = Post::find($id);

    if (Gate::denies('edit', $post)) {
        abort(403, '无权编辑该文章');
    }

    // 继续执行其他操作
}
Salin selepas log masuk

Dalam kod di atas, kami menggantikan nama kebenaran daripada "edit-post" kepada "edit", dan Gate akan secara automatik memanggil kaedah yang sepadan dalam PostPolicy untuk menyemak kebenaran.

2.4 Keadaan Dinamik

Dalam kelas dasar, kami boleh menentukan sama ada pengguna mempunyai kebenaran berdasarkan syarat yang berbeza. Contohnya, dalam kaedah edit PostPolicy, kita boleh mengubah suainya kepada kod berikut:

public function edit(User $user, Post $post)
{
    return $user->id === $post->user_id || $user->is_admin;
}
Salin selepas log masuk

Dalam contoh di atas, jika pengguna ialah pengarang atau pentadbir artikel, dia mempunyai kebenaran untuk mengedit artikel.

Ringkasan

Artikel ini memperkenalkan penggunaan lanjutan fungsi kebenaran dalam Laravel: peruntukan kebenaran dinamik. Dengan menggunakan kelas dasar, kami boleh menentukan sama ada pengguna mempunyai kebenaran yang sepadan berdasarkan keadaan dinamik untuk memenuhi keperluan kawalan kebenaran yang kompleks. Saya harap artikel ini membantu anda, dan saya juga berharap anda boleh menggunakan kaedah ini secara fleksibel dalam projek tertentu.

Atas ialah kandungan terperinci Penggunaan lanjutan fungsi kebenaran Laravel: Cara melaksanakan peruntukan kebenaran dinamik. 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

Tag artikel 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)

Kaedah Pemasangan Rangka Kerja Laravel Kaedah Pemasangan Rangka Kerja Laravel Mar 06, 2025 pm 01:59 PM

Kaedah Pemasangan Rangka Kerja Laravel

Pengurusan Menu Laravel-Admin Pengurusan Menu Laravel-Admin Mar 06, 2025 pm 02:02 PM

Pengurusan Menu Laravel-Admin

Versi Laravel apa yang terbaik Versi Laravel apa yang terbaik Mar 06, 2025 pm 01:58 PM

Versi Laravel apa yang terbaik

Bagaimana membina API RESTful dengan ciri -ciri canggih di Laravel? Bagaimana membina API RESTful dengan ciri -ciri canggih di Laravel? Mar 11, 2025 pm 04:13 PM

Bagaimana membina API RESTful dengan ciri -ciri canggih di Laravel?

Apakah amalan terbaik untuk menggunakan Laravel dalam persekitaran awan asli? Apakah amalan terbaik untuk menggunakan Laravel dalam persekitaran awan asli? Mar 14, 2025 pm 01:44 PM

Apakah amalan terbaik untuk menggunakan Laravel dalam persekitaran awan asli?

Bagaimanakah Laravel dibandingkan dengan kerangka PHP yang lain (Symfony, Codeigniter, Yii)? Bagaimanakah Laravel dibandingkan dengan kerangka PHP yang lain (Symfony, Codeigniter, Yii)? Mar 14, 2025 pm 01:49 PM

Bagaimanakah Laravel dibandingkan dengan kerangka PHP yang lain (Symfony, Codeigniter, Yii)?

Bagaimana untuk melaksanakan pengesahan dan kebenaran OAuth2 di Laravel? Bagaimana untuk melaksanakan pengesahan dan kebenaran OAuth2 di Laravel? Mar 12, 2025 pm 05:56 PM

Bagaimana untuk melaksanakan pengesahan dan kebenaran OAuth2 di Laravel?

Bagaimana saya membuat dan menggunakan arahan pisau tersuai di laravel? Bagaimana saya membuat dan menggunakan arahan pisau tersuai di laravel? Mar 17, 2025 pm 02:50 PM

Bagaimana saya membuat dan menggunakan arahan pisau tersuai di laravel?

See all articles