cari
Rumahrangka kerja phpLaravelPembangunan Laravel: Bagaimana untuk melaksanakan pengesahan API menggunakan Laravel Sanctum?

Dengan populariti API RESTful dan penggunaan aplikasi yang meluas, semakin banyak aplikasi memerlukan pengesahan dan kebenaran API, jadi keselamatan API telah menjadi aspek yang sangat penting dalam pembangunan perisian hari ini. Laravel Sanctum ialah sistem pengesahan ringan yang diperkenalkan di luar kotak dengan Laravel 7.0, yang direka untuk menjadikan pengesahan API mudah dan selamat. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Sanctum dalam Laravel untuk memastikan keselamatan API.

  1. Pasang Laravel Sanctum

Sebelum kita mula, kami perlu mengesahkan bahawa versi Laravel 7.0+ telah dipasang. Kemudian kita boleh menggunakan komposer untuk memasang dependencies Laravel Sanctum:

composer require laravel/sanctum

Selepas memasang Sanctum, tambah kod berikut pada fail config/app.php:

'providers' => [
    // ...
    LaravelSanctumSanctumServiceProvider::class,
],

'aliases' => [
    //...
    'Sanctum' => LaravelSanctumSanctum::class,
]

Dengan cara ini, aplikasi Laravel telah menggunakan Sanctum perkhidmatan dan fungsi yang disediakan.

  1. Mengkonfigurasi pangkalan data

Seterusnya, sebelum melakukan pemindahan pangkalan data, kita perlu menyediakan jadual pangkalan data Sanctum. LaravelSanctum menyediakan personal_access_tokens jadual pangkalan data secara lalai dengan medan berikut:

  • id: pengecam unik token
  • tokenable_type: yang dikaitkan dengan token Nama kelas model
  • tokenable_id: ID model yang dikaitkan dengan token
  • name: Nama token
  • token: Nilai token API
  • abilities: Keizinan token

Sebelum mencipta jadual personal_access_tokens, kita perlu mencipta perhubungan model terlebih dahulu. Ini boleh dilakukan dengan mendaftarkan perkara berikut dalam AuthServiceProvider:

use LaravelSanctumSanctum;
//...

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

    Sanctum::ignoreMigrations();

    Sanctum::actingAs( null, [
        'superuser'
    ]);
}

Sanctum::ignoreMigrations() Fail pemindahan pangkalan data yang digunakan untuk menghalang Laravel daripada melaksanakan Sanctum dalam perintah artisan migrate. Walau bagaimanapun, dalam kebanyakan kes, kami hanya menambahkannya pada arahan fail pemindahan pangkalan data. Sanctum::actingAs()Juga menyediakan kaedah pembangunan sahaja yang menyamar sebagai pengguna tanpa pengesahan pengguna.

Kemudian, kita perlu menjalankan arahan berikut untuk mencipta jadual personal_access_tokens:

php artisan migrate
  1. Buat Token API

Laravel Sanctum menyediakan kita dua cara untuk menjana token untuk API. Salah satunya ialah kaedah CreateToken, yang mencipta satu atau lebih token API dengan nama pilihan dan kebenaran yang diberikan. Di sini kami memperkenalkan kaedah kedua, iaitu menggunakan fungsi hasApiTokens() dengan fungsi createToken():

// use the HasApiTokens trait within your User Model
use LaravelSanctumHasApiTokens;

class User extends Authenticatable
{
    use HasApiTokens, Notifiable;

    // ...
}

// create a Token with User ID and given Abilities
$personalAccessToken = $user->createToken('API Token', ['server:get','server:post']);

Di sini kami menggunakan HasApiTokensTrait dalam model pengguna untuk melaksanakan fungsi token API dalam model pengguna. Kami menggunakan kaedah createToken untuk mencipta token API dan menentukan nama pilihan dan kunci kebenaran yang dibenarkan semasa membuat token.

  1. Menjaga Laluan API

Dengan kunci API di tangan, kami boleh menyuntiknya ke dalam setiap permintaan untuk pengesahan. Kami boleh menggunakan sanctum middleware dalam fail penghalaan Laravel untuk menjamin laluan API untuk mengesahkan token dalam permintaan:

// A Group of API routes that require a valid Token
Route::group(['middleware' => 'auth:sanctum'], function () {
    Route::get('/user', function (Request $request) {
        return $request->user();
    });
});

Dalam kod ini, kami mentakrifkan pengesahan sanctum kumpulan Penghalaan middleware untuk fail. Kumpulan laluan mengandungi laluan yang hanya memerlukan Token yang sah untuk diakses.

  1. Menggunakan Token Pembawa

Menggunakan BearerToken ialah cara paling biasa untuk menghantar token API melalui pengepala HTTP Authorization. Token boleh dibenarkan dengan menambahkan Authorization: Bearer {{$personalAccessToken->plainTextToken}} pada pengepala permintaan:

curl -H "Authorization: Bearer xxxxx" http://example.com/api/user
  1. Membatalkan Token API

Akhir sekali, kita perlu memahami cara membatalkan token API. Kita boleh menggunakan fungsi tokens()->delete() untuk memadam semua token API untuk pengguna, atau menggunakan fungsi revoke() untuk membatalkan satu token API:

$user->tokens()->delete();

$personalAccessToken->revoke();

Kesimpulan

Sekarang kami telah berjaya Melaksanakan Pengesahan Sanctum untuk menjamin API kami. Sanctum dan Laravel menyediakan pengesahan API yang mudah tetapi berkuasa, yang membolehkan pembangun menumpukan pada membina API yang berkuasa dan meletakkan fokus utama pada logik perniagaan. Apabila menggunakan Sanctum, amat disyorkan agar anda membaca dokumentasi rasmi dengan teliti supaya anda boleh memahami sepenuhnya proses pengesahan API dan memastikan keselamatan tertinggi untuk aplikasi anda.

Atas ialah kandungan terperinci Pembangunan Laravel: Bagaimana untuk melaksanakan pengesahan API menggunakan Laravel Sanctum?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Laravel dalam Tindakan: Aplikasi dan contoh dunia nyataLaravel dalam Tindakan: Aplikasi dan contoh dunia nyataApr 16, 2025 am 12:02 AM

Laravelcanbeeffectivelyedinreal-worldapplicationsforbuildingscalableWebsolutions.1) itsimplifiescrudoperationsinrestfulapisusingeloquentorm.2) laravel'secosystem, termasuktoolslikenova, enhancesdevelopment.3)

Fungsi Utama Laravel: Pembangunan BackendFungsi Utama Laravel: Pembangunan BackendApr 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.

Keupayaan backend Laravel: pangkalan data, logik, dan banyak lagiKeupayaan backend Laravel: pangkalan data, logik, dan banyak lagiApr 14, 2025 am 12:04 AM

Laravel melakukan dengan kuat dalam pembangunan back-end, memudahkan operasi pangkalan data melalui eloquentorm, pengawal dan kelas perkhidmatan mengendalikan logik perniagaan, dan menyediakan barisan, acara dan fungsi lain. 1) Jadual pangkalan data Peta Eloquentorm melalui model untuk memudahkan pertanyaan. 2) Logik perniagaan diproses dalam pengawal dan kelas perkhidmatan untuk meningkatkan modulariti dan penyelenggaraan. 3) Fungsi lain seperti sistem giliran membantu menangani keperluan yang kompleks.

Fleksibiliti Laravel: Dari laman web mudah ke sistem yang kompleksFleksibiliti Laravel: Dari laman web mudah ke sistem yang kompleksApr 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.

Laravel (PHP) vs Python: Persekitaran Pembangunan dan EkosistemLaravel (PHP) vs Python: Persekitaran Pembangunan dan EkosistemApr 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.

Laravel dan backend: Powering Web Application LogicLaravel dan backend: Powering Web Application LogicApr 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.

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.

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.

See all articles

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)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.