Rumah rangka kerja php Laravel Cara menggunakan Laravel untuk melaksanakan pengurusan kebenaran untuk aplikasi dipisahkan bahagian hadapan dan belakang

Cara menggunakan Laravel untuk melaksanakan pengurusan kebenaran untuk aplikasi dipisahkan bahagian hadapan dan belakang

Apr 14, 2023 am 09:34 AM

Laravel ialah salah satu rangka kerja PHP paling popular pada masa ini, yang menyediakan sokongan kuat untuk pembangunan aplikasi web. Rangka kerja Laravel juga menyediakan sokongan yang sangat baik untuk model pembangunan pemisahan bahagian hadapan dan belakang, yang boleh membantu pembangun membangun dengan lebih cekap. Dalam aplikasi dengan pemisahan bahagian hadapan dan belakang, pengurusan kebenaran merupakan bahagian yang sangat penting Artikel ini akan memperkenalkan cara menggunakan Laravel untuk melaksanakan pengurusan kebenaran aplikasi pemisahan bahagian hadapan dan belakang.

1. Apakah aplikasi pemisah bahagian hadapan dan belakang?

Aplikasi pemisah bahagian hadapan dan bahagian belakang merujuk kepada pengasingan teknologi yang digunakan oleh bahagian hadapan daripada teknologi yang digunakan oleh bahagian hadapan dan bahagian belakang bukan lagi keseluruhan, tetapi berkomunikasi melalui API antara muka. Bahagian hadapan biasanya dilaksanakan menggunakan rangka kerja JavaScript, manakala bahagian belakang dilaksanakan menggunakan bahasa seperti PHP dan Java.

Dalam aplikasi pemisahan bahagian hadapan dan bahagian belakang, bahagian hadapan dan bahagian belakang masing-masing bertanggungjawab untuk logik perniagaan mereka sendiri bertanggungjawab untuk pelaksanaan antara muka UI dan pengguna interaksi, dan bahagian belakang bertanggungjawab untuk pemprosesan data dan pelaksanaan logik perniagaan. Oleh kerana aplikasi pemisahan bahagian hadapan dan bahagian belakang memisahkan bahagian hadapan dan bahagian belakang, ia membolehkan pembangun menumpukan lebih pada bidang kepakaran mereka, dengan itu meningkatkan kecekapan pembangunan.

2. Mengapa pengurusan kebenaran diperlukan?

Dalam aplikasi, kawalan akses merupakan aspek yang sangat penting. Jika tiada kawalan capaian yang berkesan, penyerang mudah mengeksploitasi kelemahan untuk melakukan operasi yang menyalahi undang-undang, seperti mengubah suai data, memadamkan data, dsb. Oleh itu, adalah sangat perlu untuk menambah pengurusan kebenaran kepada aplikasi.

Pengurusan kebenaran merujuk kepada pengurusan kebenaran setiap peranan dalam sistem. Biasanya beberapa peranan tetap ditakrifkan, seperti pentadbir, pengguna biasa, dsb., setiap peranan mempunyai keizinan fungsi yang berbeza. Pentadbir mempunyai kuasa tertinggi dan boleh mengendalikan semua data dalam sistem pengguna biasa hanya boleh melakukan beberapa operasi asas.

Dalam aplikasi pemisahan bahagian hadapan dan belakang, kaedah pengurusan kebenaran yang biasa digunakan ialah pengurusan kebenaran Token. Bahagian hadapan perlu membawa Token semasa menghantar permintaan, dan bahagian belakang mengesahkan Token untuk menentukan sama ada pengguna mempunyai hak akses. Oleh itu, setiap permintaan yang diterima daripada bahagian hadapan memerlukan pengesahan token.

3. Bagaimana untuk merealisasikan pengurusan kebenaran aplikasi yang dipisahkan di bahagian hadapan dan bahagian belakang?

Dalam rangka kerja Laravel, pengurusan kebenaran biasanya dilaksanakan melalui Laratrust. Laratrust ialah perpustakaan pengurusan kebenaran Laravel yang sangat mudah digunakan Ia boleh digunakan untuk melaksanakan pengurusan peranan dan pengurusan kebenaran dengan sangat mudah.

Berikut ialah langkah-langkah tentang cara menggunakan Laratrust untuk melaksanakan pengurusan kebenaran untuk aplikasi yang dipisahkan bahagian hadapan dan belakang:

  1. Pasang Laratrust

Pasang menggunakan Komposer dalam pustaka Laratrust projek Laravel:

composer require santigarcor/laratrust
Salin selepas log masuk
  1. Jalankan arahan keluaran Laratrust

Terbitkan fail konfigurasi Laratrust, fail migrasi, dsb.:

php artisan vendor:publish --provider="Spatie\Permission\PermissionServiceProvider" --tag="laratrust"
Salin selepas log masuk
  1. Jalankan arahan migrasi Laratrust

Jalankan arahan migrasi Laratrust untuk menjana Peranan, Kebenaran, Role_User dan jadual lain:

php artisan migrate
Salin selepas log masuk
  1. Konfigurasikan Laratrust

Dalam fail config/auth.php, konfigurasikan guard sebagai api:

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],

    'api' => [
        'driver' => 'token',
        'provider' => 'users',
    ],
],
Salin selepas log masuk

Dalam fail config/laratrust.php, tentukan peranan dan kebenaran:

'roles' => [
    'admin' => 'Admin',
    'user' => 'User',
],

'permissions' => [
    'create-post' => 'Create Post',
    'update-post' => 'Update Post',
    'delete-post' => 'Delete Post',
],
Salin selepas log masuk
  1. Cipta Token

Dalam UserController, tambahkan kaedah untuk mencipta Token:

public function createToken(Request $request)
{
    $user = $request->user();
    $token = $user->createToken('api_token')->accessToken;
    return [$token];
}
Salin selepas log masuk
  1. Tambah perisian tengah Token

dalam fail app /Http/Kernel.php, tambah perisian tengah Token:

protected $routeMiddleware = [
    // ...
    'token' => \App\Http\Middleware\TokenMiddleware::class,
];
Salin selepas log masuk

Dalam fail app/Http/Middleware/TokenMiddleware.php, sahkan Token:

public function handle($request, Closure $next)
{
    $token = $request->header('Authorization');
    if (!$token) {
        return response(['message' => 'Token not provided'], 401);
    }
    $user = User::where('api_token', $token)->first();
    if (!$user) {
        return response(['message' => 'Invalid token'], 401);
    }
    return $next($request);
}
Salin selepas log masuk
  1. Gunakan middleware Token dalam laluan

Dalam laluan, tambah middleware Token:

Route::group(['middleware' => ['token', 'role:admin']], function () {
    Route::post('/posts', 'PostController@store');
    Route::put('/posts/{post}', 'PostController@update');
    Route::delete('/posts/{post}', 'PostController@destroy');
});
Salin selepas log masuk

Dalam kod di atas, setiap permintaan perlu lulus Perisian tengah token menjalankan pengesahan dan perlu mengesahkan sama ada ia mempunyai kebenaran peranan pentadbir.

4. Ringkasan

Artikel ini memperkenalkan cara menggunakan Laravel untuk melaksanakan pengurusan kebenaran untuk aplikasi yang dipisahkan di bahagian hadapan dan bahagian belakang. Pengurusan peranan dan pengurusan kebenaran boleh dilaksanakan dengan mudah menggunakan perpustakaan Laratrust, dan perisian tengah Token boleh digunakan untuk mengesahkan setiap permintaan untuk memastikan keselamatan aplikasi.

Dalam pembangunan sebenar, pengurusan kebenaran adalah bahagian yang sangat diperlukan dan perlu dikonfigurasikan secara fleksibel mengikut keperluan sebenar. Saya harap artikel ini dapat membantu pembangun yang perlu melaksanakan pengurusan kebenaran.

Atas ialah kandungan terperinci Cara menggunakan Laravel untuk melaksanakan pengurusan kebenaran untuk aplikasi dipisahkan bahagian hadapan dan belakang. 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.

Contoh Pengenalan Laravel Contoh Pengenalan Laravel Apr 18, 2025 pm 12:45 PM

Laravel adalah rangka kerja PHP untuk membina aplikasi web yang mudah. Ia menyediakan pelbagai ciri yang kuat termasuk: Pemasangan: Pasang Laravel CLI secara global dengan komposer dan buat aplikasi dalam direktori projek. Routing: Tentukan hubungan antara URL dan pengendali dalam laluan/web.php. Lihat: Buat pandangan dalam sumber/pandangan untuk menjadikan antara muka aplikasi. Integrasi Pangkalan Data: Menyediakan integrasi keluar-of-the-box dengan pangkalan data seperti MySQL dan menggunakan penghijrahan untuk membuat dan mengubah suai jadual. Model dan Pengawal: Model mewakili entiti pangkalan data dan proses pengawal permintaan HTTP.

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.

Cara Belajar Laravel Cara Belajar Laravel secara percuma Cara Belajar Laravel Cara Belajar Laravel secara percuma Apr 18, 2025 pm 12:51 PM

Mahu mempelajari rangka kerja Laravel, tetapi tidak mengalami sumber atau tekanan ekonomi? Artikel ini memberikan anda pembelajaran percuma Laravel, mengajar anda cara menggunakan sumber seperti platform dalam talian, dokumen dan forum komuniti untuk meletakkan asas yang kukuh untuk perjalanan pembangunan PHP anda dari mula menguasai.

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.

See all articles