Rumah rangka kerja php Laravel Pengenalan terperinci kepada proses, konfigurasi dan penggunaan Pasport Laravel

Pengenalan terperinci kepada proses, konfigurasi dan penggunaan Pasport Laravel

Apr 23, 2023 am 09:17 AM

Laravel Passport ialah pelaksanaan pelayan OAuth2 yang lengkap di bawah rangka kerja Laravel Ia membolehkan anda mengesahkan dan membenarkan identiti pengguna melalui API, supaya perkhidmatan API boleh diakses tanpa mendedahkan bukti kelayakan pengguna, yang sangat mengurangkan kesukaran pelanggan pembangunan meningkatkan keselamatan aplikasi.

Protokol OAuth2 di sebalik Laravel Passport ialah standard industri, jadi anda boleh menyepadukan pengesahan dan kebenaran OAuth2 dengan mudah dalam bahasa dan rangka kerja lain menggunakan alatan dan proses yang sama. Di bawah, artikel ini akan memperkenalkan proses, konfigurasi dan penggunaan Pasport Laravel secara terperinci.

Pasang Pasport

Sebelum menggunakan Laravel Passport, anda perlu memasangnya. Kita boleh menggunakan arahan composer untuk memasang Passport, arahannya adalah seperti berikut:

composer require laravel/passport
Salin selepas log masuk

Enable Passport

Selepas Laravel Passport dipasang, anda perlu menambah penyedia perkhidmatannya pada config/ tatasusunan penyedia fail app.php, buka fail, cari tatasusunan penyedia dan tambah penyedia perkhidmatan Pasport Laravel seperti berikut:

'providers' => [
    // Other Service Providers...
    Laravel\Passport\PassportServiceProvider::class,
],
Salin selepas log masuk

Buat jadual pangkalan data

Sebelum menggunakan Pasport Laravel, juga Untuk mencipta jadual pangkalan data baharu yang diperlukan oleh Pasport, anda boleh menggunakan perintah artisan berikut untuk menjana fail migrasi:

php artisan migrate
Salin selepas log masuk

Selepas melaksanakan arahan di atas, Laravel Passport akan mencipta beberapa jadual baharu dalam pangkalan data anda untuk disimpan Data OAuth2 seperti pelanggan, Token Akses dan Token Segar Semula.

Terbitkan fail konfigurasi

Laksanakan perintah artisan berikut untuk menerbitkan fail konfigurasi Pasport ke direktori konfigurasi projek Laravel:

php artisan vendor:publish --tag=passport-config
Salin selepas log masuk

Buat kunci

Pada ketika ini, kami telah melengkapkan prasyarat yang diperlukan untuk menggunakan Pasport Laravel. Seterusnya, kita perlu menggunakan perintah artisan berikut untuk menjana kunci penyulitan:

php artisan passport:keys
Salin selepas log masuk

Arahan di atas akan menjana kunci penyulitan untuk menandatangani data seperti kuki dan token akses.

Mengkonfigurasi Pasport

Selepas melengkapkan langkah di atas, seterusnya kita perlu mengkonfigurasi Pasport supaya ia boleh dijalankan. Dalam fail konfigurasi config/auth.php, tukar pemacu pemacu api kepada pasport, dan tetapkan pengawal dan pembekal seperti berikut:

'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],
    'api' => [
        'driver' => 'passport',
        'provider' => 'users',
    ],
],
Salin selepas log masuk

Konfigurasikan penyedia dalam fail yang sama seperti berikut :

'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => App\Models\User::class,
    ],
],
Salin selepas log masuk

Setelah fail konfigurasi selesai, pengesahan API sudah sedia.

Buat Laluan

Seterusnya, kita perlu mencipta laluan API dalam fail laluan aplikasi/Http seperti berikut:

Route::middleware('auth:api')->get('/user', function (Request $request) {
    return $request->user();
});
Salin selepas log masuk

Dalam contoh laluan di atas, tentukan auth:api middleware dipasang untuk mengesahkan sama ada permintaan itu datang daripada pengguna yang disahkan Jika ia bukan pengguna yang disahkan, kod status 401 akan dikembalikan apabila pengesahan gagal.

Buat Pelanggan

Sekarang kami telah melengkapkan konfigurasi aplikasi dan tetapan penghalaan API, kami perlu mencipta klien API. Dalam Pasport Laravel, pasport perintah artisan:klien disediakan untuk membuat pelanggan OAuth2 baharu. Jalankan arahan seperti yang ditunjukkan di bawah:

php artisan passport:client --client
Salin selepas log masuk

Selepas melaksanakan arahan tersebut, kita perlu memasukkan nama klien dan URI hala keizinan seperti yang ditunjukkan di bawah:

php artisan passport:client --client
Which user ID should the client be assigned to? [0]:
 > 1
What should we name the client?
 > Test
Where should we redirect the request after authorization?
 > http://example.com/callback
Salin selepas log masuk

Arahan di atas akan mencipta A pelanggan OAuth2 baharu untuk menghantar permintaan ke API aplikasi ini. Kami akan mendapat ID pelanggan dan rahsia pelanggan untuk digunakan dalam permintaan API berikutnya.

Dapatkan keizinan

Pelanggan telah dibuat dan memperoleh URI ubah hala keizinan Sekarang kita perlu menghantar permintaan kepada URI untuk mendapatkan kebenaran. Selepas itu, Pasport akan menjana token akses untuk pelanggan dan mengembalikannya kepada pelanggan. Gunakan URL yang ditunjukkan di bawah, menggantikan ID Pelanggan dan Ubah Hala URI:

http://your-app.com/oauth/authorize?client_id={client-id}&redirect_uri={redirect-uri} &response_type=code&scope=
Salin selepas log masuk

Selepas memasukkan URL, skrin kebenaran OAuth2 yang ditunjukkan di bawah akan dipaparkan:

Pengenalan terperinci kepada proses, konfigurasi dan penggunaan Pasport Laravel

Selepas mengklik butang 'Betulkan', kebenaran akan berlaku dan mengubah hala ke URI ubah hala.

Dapatkan Token Akses

Kini kami telah mendapat kebenaran dan pelanggan telah diberikan akses kepada API. Kita perlu menggunakan kod kebenaran OAuth2 untuk menukar kunci klien untuk token akses Kita boleh menggunakan arahan curl seperti yang ditunjukkan di bawah untuk mendapatkan token akses daripada pelayan kebenaran API:

$ curl -X POST -H "Accept: application/json" -F "client_id={client-id}" -F "client_secret={client-secret}" -F "grant_type=authorization_code" -F "code={code}" -F "redirect_uri={redirect-uri}" http://your-app.com/oauth/token
Salin selepas log masuk

Selepas melaksanakan. arahan di atas, Anda akan mendapat objek JSON seperti yang ditunjukkan di bawah, yang mengandungi maklumat seperti access_token dan refresh_token:

{
    "token_type": "Bearer",
    "expires_in": 86400,
    "access_token": "{access-token}",
    "refresh_token": "{refresh-token}",
}
Salin selepas log masuk

Menggunakan token akses untuk membuat permintaan API

Sekarang kami telah memperoleh token akses, kami Token akses boleh digunakan untuk membuat permintaan dengan API. Kami perlu menambah pengepala Kebenaran pada pengepala permintaan API, menetapkan skema pengesahan Pembawa dan menggunakan token akses sebagai kandungan token, seperti yang ditunjukkan di bawah:

$client = new \GuzzleHttp\Client();
$response = $client->request('GET', 'http://your-app.com/api/user', [
    'headers' => [
        'Authorization' => 'Bearer '.$accessToken,
        'Accept' => 'application/json',
    ],
]);
Salin selepas log masuk

Dalam kod di atas, kami akan The token akses diserahkan kepada pelayan API dalam format TOKEN Pembawa untuk pengesahan Jika berjaya, keputusan respons API akan diperolehi.

Ringkasan

Dalam artikel ini, kami menerangkan proses, konfigurasi dan penggunaan Pasport Laravel. Menggunakan Pasport Laravel, kami boleh menambah pengesahan dan keizinan selamat dengan cepat pada aplikasi API, sambil menyokong protokol OAuth2 dan saling beroperasi dengan aplikasi yang melaksanakan kebenaran OAuth2 dalam bahasa pengaturcaraan dan rangka kerja lain, membolehkan pembangun membina keselamatan dengan cepat Tinggi, mudah untuk- menggunakan aplikasi API.

Atas ialah kandungan terperinci Pengenalan terperinci kepada proses, konfigurasi dan penggunaan Pasport 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.

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