Jadual Kandungan
Apakah Keizinan Laravel
Jenis kebenaran Laravel
Keizinan perisian tengah
Keizinan Dasar
Pelaksanaan Keizinan Laravel
Keizinan Perisian Tengah
Keizinan Strategi
Ringkasan
Rumah rangka kerja php Laravel Terokai mekanisme kebenaran dan kaedah pelaksanaan dalam Laravel

Terokai mekanisme kebenaran dan kaedah pelaksanaan dalam Laravel

Apr 21, 2023 am 10:06 AM

Laravel ialah rangka kerja PHP yang popular digunakan untuk membina pelbagai jenis aplikasi web. Apabila anda membina aplikasi web, anda selalunya perlu mengurus dan melindungi pengguna dan sumber, yang memerlukan pengurusan kebenaran akses.

Laravel menyediakan kaedah pengesahan dan kebenaran yang ringkas namun berkuasa yang boleh memberikan tahap kebenaran yang berbeza kepada pengguna aplikasi dengan mudah. Dalam artikel ini, kami akan meneroka mekanisme kebenaran dalam Laravel dan cara melaksanakannya.

Apakah Keizinan Laravel

Keizinan merujuk kepada proses mentakrif dan melaksanakan kawalan akses dalam aplikasi. Ini termasuk mengesahkan siapa pengguna, mengesahkan identiti mereka dan mengesahkan bahawa mereka diberikan akses kepada sumber yang dikongsi.

Dalam Laravel, kebenaran merujuk kepada tindakan khusus yang boleh dilakukan oleh pengguna atau sumber khusus yang boleh mereka akses. Ia ditentukan berdasarkan peranan atau lesen pengguna untuk melindungi operasi atau sumber sensitif dalam aplikasi.

Jenis kebenaran Laravel

Dalam Laravel, terdapat dua jenis kebenaran: kebenaran perisian tengah dan kebenaran dasar.

Keizinan perisian tengah

Keizinan perisian tengah dilaksanakan melalui mekanisme perisian tengah Laravel. Middleware ialah sekeping kod yang melaksanakan antara permintaan HTTP dan respons dan boleh digunakan untuk menyelesaikan pelbagai tugas seperti pengesahan permintaan, kebenaran, operasi pengelogan, dsb.

Apabila menggunakan kebenaran middleware, setiap middleware menyemak syarat tertentu. Jika syarat tidak dipenuhi, middleware menafikan permintaan dan anda boleh mengubah hala pengguna ke halaman log masuk atau halaman ralat lain.

Keizinan Dasar

Keizinan Polisi ialah sistem kebenaran diskret yang mewakili setiap model dalam permohonan anda. Apabila menggunakan kebenaran dasar, anda boleh menentukan hak penggunaan untuk setiap model, seperti membaca, mencipta, mengemas kini dan memadam data.

Apabila menggunakan kebenaran dasar, anda boleh menetapkan kaedah untuk mengendalikan logik kebenaran. Jika semakan kebenaran gagal, Laravel akan membuang pengecualian 403 Forbidden secara automatik.

Pelaksanaan Keizinan Laravel

Keizinan Perisian Tengah

Untuk menggunakan keizinan perisian tengah, laksanakan perisian tengah dan tambahkannya pada laluan anda. Middleware harus menyemak syarat tertentu dan menghentikan permintaan jika syarat tidak dipenuhi.

Berikut ialah contoh pelaksanaan perisian tengah yang menyemak sama ada pengguna mempunyai peranan tertentu:

namespace App\Http\Middleware;

use Closure;
use Illuminate\Support\Facades\Auth;

class RoleMiddleware
{
    public function handle($request, Closure $next, $role)
    {
        if (! Auth::user()->hasRole($role)) {
            return redirect('/home');
        }

        return $next($request);
    }
}
Salin selepas log masuk

Untuk menggunakan perisian tengah ini, daftarkannya dengan app/Http/Kernel.php dalam fail $routeMiddleware 🎜 > dalam hartanah.

protected $routeMiddleware = [
    'role' => \App\Http\Middleware\RoleMiddleware::class,
];
Salin selepas log masuk

Kini anda boleh menggunakan role perisian tengah dalam laluan anda.

Route::group(['middleware' => ['role:admin']], function () {
    Route::get('/dashboard', function () {
        // Your code
    });
});
Salin selepas log masuk

Kod di atas akan menyemak sama ada pengguna mempunyai peranan admin dan ubah hala ke halaman utama jika tidak. Anda boleh mengubah suai pelaksanaan middleware mengikut keperluan.

Keizinan Strategi

Keizinan Strategi ialah sistem kebenaran diskret yang berkaitan dengan model. Anda mesti mengikuti langkah berikut untuk melaksanakan kebenaran dasar:

  1. Jana dasar

Gunakan perintah make:policy untuk menjana kelas dasar:

php artisan make:policy ArticlePolicy --model=Article
Salin selepas log masuk

Perintah ini akan mencipta kelas bernama app/Policies dalam direktori ArticlePolicy. Anda boleh menentukan logik kebenaran untuk setiap model Article dalam kelas ini.

  1. Daftar polisi

Daftar polisi dalam atribut app/Providers/AuthServiceProvider.php fail $policies:

use App\Article;
use App\Policies\ArticlePolicy;

protected $policies = [
    Article::class => ArticlePolicy::class,
];
Salin selepas log masuk
  1. Buat kebenaran kaedah

Kini anda boleh melaksanakan logik kebenaran dalam dasar anda. Contohnya, anda boleh mencipta kaedah yang boleh mengedit artikel:

public function update(User $user, Article $article)
{
    return $user->id === $article->user_id;
}
Salin selepas log masuk

Kod di atas menyemak sama ada pengguna semasa ialah pengarang artikel dan jika ya, boleh mengubah suai artikel. Jika tidak, halaman penyuntingan artikel tidak boleh diakses.

Untuk menggunakan kebenaran dasar dalam pengawal, sila hubungi kaedah update sebelum mengakses kaedah authorize:

public function update(Article $article, Request $request)
{
    $this->authorize('update', $article);

    // Your code
}
Salin selepas log masuk

Kod di atas akan menyemak sama ada pengguna mempunyai kebenaran untuk mengubah suai artikel, Jika tidak, pengecualian 403 Forbidden akan dilemparkan.

Ringkasan

Laravel menyediakan mekanisme kebenaran yang ringkas namun berkuasa yang membolehkan kami mentakrifkan tahap kebenaran yang berbeza untuk pengguna aplikasi dengan mudah. Keizinan middleware dan kebenaran dasar ialah dua jenis kebenaran Laravel, yang boleh menangani senario yang berbeza.

Melalui pengenalan artikel ini, saya percaya anda telah menguasai konsep dan kaedah pelaksanaan kebenaran Laravel Jika anda membina aplikasi web yang memerlukan pengurusan hak pengguna, pengetahuan ini akan menjadi senjata untuk anda.

Atas ialah kandungan terperinci Terokai mekanisme kebenaran dan kaedah pelaksanaan 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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

Mana yang lebih baik, Django atau Laravel? Mana yang lebih baik, Django atau Laravel? Mar 28, 2025 am 10:41 AM

Kedua-dua Django dan Laravel adalah kerangka kerja penuh. Django sesuai untuk pemaju python dan logik perniagaan yang kompleks, manakala Laravel sesuai untuk pemaju PHP dan sintaks elegan. 1.Django didasarkan pada python dan mengikuti falsafah "lengkap bateri", sesuai untuk perkembangan pesat dan kesesuaian yang tinggi. 2. Laravel didasarkan pada PHP, menekankan pengalaman pemaju, dan sesuai untuk projek kecil dan sederhana.

Laravel dan backend: Powering Web Application Logic Laravel dan backend: Powering Web Application Logic Apr 11, 2025 am 11:29 AM

Bagaimanakah Laravel memainkan peranan dalam logik backend? Ia memudahkan dan meningkatkan pembangunan backend melalui sistem penghalaan, eloquentorm, pengesahan dan kebenaran, acara dan pendengar, dan pengoptimuman prestasi. 1. Sistem penghalaan membolehkan definisi struktur URL dan logik pemprosesan permintaan. 2.eloquentorm memudahkan interaksi pangkalan data. 3. Sistem pengesahan dan kebenaran adalah mudah untuk pengurusan pengguna. 4. Acara dan pendengar melaksanakan struktur kod yang ditambah dengan longgar. 5. Pengoptimuman prestasi meningkatkan kecekapan aplikasi melalui caching dan beratur.

PHP atau Laravel mana yang lebih baik? PHP atau Laravel mana yang lebih baik? Mar 27, 2025 pm 05:31 PM

PHP dan Laravel tidak dapat dibandingkan secara langsung, kerana Laravel adalah rangka kerja berasaskan PHP. 1.Php sesuai untuk projek kecil atau prototaip cepat kerana ia mudah dan langsung. 2. Laravel sesuai untuk projek besar atau pembangunan yang cekap kerana ia menyediakan fungsi dan alat yang kaya, tetapi mempunyai lengkung pembelajaran yang curam dan mungkin tidak sebaik php tulen.

Adakah Laravel adalah frontend atau backend? Adakah Laravel adalah frontend atau backend? Mar 27, 2025 pm 05:31 PM

LaravelisabackendFramWorkBuiltonPHP, Direka ForweBapplicationDevelopment.itfocusesonServer-Sidelogic, DatabaseManagement, andApplications Structure, andCanbeIntegratedWithFrontendTechnologiesLikeVue.jsorreactorfull-stackdevelopment.

Fleksibiliti Laravel: Dari laman web mudah ke sistem yang kompleks Fleksibiliti Laravel: Dari laman web mudah ke sistem yang kompleks Apr 13, 2025 am 12:13 AM

Projek Pembangunan Laravel telah dipilih kerana fleksibiliti dan kuasa untuk memenuhi keperluan saiz dan kerumitan yang berbeza. Laravel menyediakan sistem penghalaan, eloquentorm, baris perintah artisan dan fungsi lain, menyokong pembangunan dari blog mudah ke sistem peringkat perusahaan yang kompleks.

Mengapa Laravel begitu popular? Mengapa Laravel begitu popular? Apr 02, 2025 pm 02:16 PM

Populariti Laravel termasuk proses pembangunan mudahnya, menyediakan persekitaran pembangunan yang menyenangkan, dan ciri -ciri yang kaya. 1) Ia menyerap falsafah reka bentuk Rubyonrails, menggabungkan fleksibiliti PHP. 2) Menyediakan alat seperti eloquentorm, enjin templat bilah, dan lain -lain untuk meningkatkan kecekapan pembangunan. 3) Mekanisme suntikan seni bina dan ketergantungan MVC menjadikan kod lebih modular dan boleh diuji. 4) Menyediakan alat debugging yang kuat dan kaedah pengoptimuman prestasi seperti sistem caching dan amalan terbaik.

Fungsi Utama Laravel: Pembangunan Backend Fungsi Utama Laravel: Pembangunan Backend Apr 15, 2025 am 12:14 AM

Fungsi teras Laravel dalam pembangunan back-end termasuk sistem penghalaan, eloquentorm, fungsi penghijrahan, sistem cache dan sistem giliran. 1. Sistem penghalaan memudahkan pemetaan URL dan meningkatkan organisasi dan penyelenggaraan kod. 2.eloquentorm menyediakan operasi data berorientasikan objek untuk meningkatkan kecekapan pembangunan. 3. Fungsi penghijrahan menguruskan struktur pangkalan data melalui kawalan versi untuk memastikan konsistensi. 4. Sistem cache mengurangkan pertanyaan pangkalan data dan meningkatkan kelajuan tindak balas. 5. Sistem giliran berkesan memproses data berskala besar, elakkan menghalang permintaan pengguna, dan meningkatkan prestasi keseluruhan.

Laravel (PHP) vs Python: Persekitaran Pembangunan dan Ekosistem Laravel (PHP) vs Python: Persekitaran Pembangunan dan Ekosistem Apr 12, 2025 am 12:10 AM

Perbandingan antara Laravel dan Python dalam persekitaran pembangunan dan ekosistem adalah seperti berikut: 1. Persekitaran pembangunan Laravel adalah mudah, hanya PHP dan komposer diperlukan. Ia menyediakan pelbagai pakej lanjutan seperti Laravelforge, tetapi penyelenggaraan pakej lanjutan mungkin tidak tepat pada masanya. 2. Persekitaran pembangunan Python juga mudah, hanya Python dan PIP diperlukan. Ekosistem adalah besar dan meliputi pelbagai bidang, tetapi pengurusan versi dan pergantungan mungkin kompleks.

See all articles