Bagaimana membina API REST dengan Laravel?
Jul 30, 2025 am 03:41 AMBuat projek Laravel baru dan mulakan perkhidmatan; 2. Menjana model, penghijrahan dan pengawal dan jalankan penghijrahan; 3. Tentukan laluan RESTful dalam Laluan/API.PHP; 4. Melaksanakan kaedah tambahan, penghapusan, pengubahsuaian dan pertanyaan dalam postcontroller dan mengembalikan respons JSON; 5. Uji fungsi API dengan Postman atau Curl; 6. Pilihan menambah pengesahan API melalui Sanctum; Akhirnya dapatkan struktur yang jelas, API Laravel REST yang lengkap dan boleh diperpanjang sesuai untuk aplikasi praktikal.
Membina API REST dengan Laravel adalah terima kasih kepada ciri-ciri terbina dalam untuk penghalaan, fasih Orm, dan pengendalian permintaan. Berikut adalah panduan praktikal untuk membantu anda membuat API REST yang bersih dan berfungsi menggunakan Laravel.

1. Sediakan projek Laravel baru
Mulakan dengan membuat projek Laravel baru menggunakan komposer:
Komposer membuat projek Laravel/Laravel API-Demo CD API-Demo
Kemudian, mulakan pelayan pembangunan untuk mengesahkan semuanya berfungsi:

PHP Artisan berkhidmat
Anda harus melihat halaman Selamat Datang Laravel di http://localhost:8000
.
2. Buat model, penghijrahan, dan pengawal
Mari kita bina API mudah untuk menguruskan jawatan . Gunakan perintah make:model
-a
untuk menghasilkan model, penghijrahan, kilang, dan pengawal:

PHP Artisan Make: Model Post -A
Ini mencipta:
-
app/Models/Post.php
- Model Fasih -
database/migrations/xxxx_create_posts_table.php
- penghijrahan -
app/Http/Controllers/PostController.php
- Pengawal -
database/factories/PostFactory.php
- untuk melihat
Edit fail penghijrahan untuk menentukan medan pos:
// dalam pangkalan data/migrasi /..._ create_posts_table.php Skema :: Create ('Posts', Function (Blueprint $ Table) { $ Table-> id (); $ Table-> String ('Tajuk'); $ Table-> Text ('Body'); $ Table-> Timestamps (); });
Jalankan penghijrahan:
PHP Artisan berhijrah
3. Tentukan laluan API
Buka routes/api.php
dan tentukan laluan yang tenang menggunakan Route::apiResource()
:
Gunakan App \ Http \ Controllers \ PostController; Route :: ApireSource ('Posts', PostController :: Class);
Laluan ini secara automatik memetakan tindakan rehat standard:
-
GET /api/posts
→ Indeks -
POST /api/posts
→ Simpan -
GET /api/posts/{id}
→ Tunjukkan -
PUT/PATCH /api/posts/{id}
→ kemas kini -
DELETE /api/posts/{id}
→ Destroy
Anda boleh melihat semua laluan dengan:
Laluan Artisan PHP: Senarai --Path = API
4. Melaksanakan kaedah pengawal
Buka app/Http/Controllers/PostController.php
dan isi logik menggunakan fasih.
Gunakan App \ Models \ Post; Gunakan Illuminate \ http \ request; PostController Kelas Memperluas Pengawal { Indeks Fungsi Awam () { respons balik ()-> json (post :: all ()); } Kedai Fungsi Awam (permintaan $ permintaan) { $ disahkan = $ permintaan-> validate ([ 'Tajuk' => 'Diperlukan | String | Max: 255', 'badan' => 'diperlukan | rentetan', ]); $ pos = pos :: create ($ disahkan); tindak balas kembali ()-> json ($ post, 201); } Pertunjukan Fungsi Awam ($ ID) { $ pos = pos :: cari ($ id); jika (! $ post) { REBATION RESPONSE ()-> JSON (['MESSAGE' => 'POST TIDAK DIPERLUKAN'], 404); } tindak balas kembali ()-> json ($ pos); } Kemas kini Fungsi Awam (permintaan $ permintaan, $ id) { $ pos = pos :: cari ($ id); jika (! $ post) { REBATION RESPONSE ()-> JSON (['MESSAGE' => 'POST TIDAK DIPERLUKAN'], 404); } $ disahkan = $ permintaan-> validate ([ 'Tajuk' => 'Diperlukan | String | Max: 255', 'badan' => 'diperlukan | rentetan', ]); $ post-> kemas kini ($ disahkan); tindak balas kembali ()-> json ($ pos); } Fungsi awam memusnahkan ($ id) { $ pos = pos :: cari ($ id); jika (! $ post) { REBATION RESPONSE ()-> JSON (['MESSAGE' => 'POST TIDAK DIPERLUKAN'], 404); } $ post-> padam (); respons balik ()-> json (['message' => 'post dipadam']); } }
? Laravel secara automatik mengembalikan respons JSON apabila anda lulus data ke
response()->json()
. Juga, laluan API sudah dilindungi oleh bukti CSRF dan menggunakan middlewareapi
(tanpa stat).
5. Uji API
Gunakan alat seperti Postman , Curl , atau Thunder Client (VS Code) untuk menguji titik akhir anda.
Contoh: Buat siaran dengan curl
curl -x post http: // localhost: 8000/api/post \ -H "jenis kandungan: aplikasi/json" \ -d '{"tajuk": "jawatan pertama saya", "badan": "Ini badan"}'
Anda harus mendapatkan respons JSON dengan jawatan yang dibuat dan status 201
.
6. (Pilihan) Tambahkan Pengesahan API dengan Sanctum
Untuk laluan yang dilindungi, gunakan Sanctum Laravel untuk menambah pengesahan berasaskan token.
Pasang Sanctum:
Komposer memerlukan laravel/sanctum PHP Artisan Vendor: Terbitkan --Provider = "Laravel \ Sanctum \ SanctumserviceProvider" PHP Artisan berhijrah
Tambah middleware sanctum dalam app/Http/Kernel.php
di bawah 'api'
:
'api' => [ \ Laravel \ sanctum \ http \ middleware \ memastikanfrontendrequestsarestatence :: class, 'Throttle: Api', \ Illuminate \ routing \ middleware \ penggantianbinding :: kelas, ],
Lindungi Laluan Anda:
Laluan :: Middleware ('Auth: Sanctum')-> Apiresource ('Posts', PostController :: Class);
Sekarang pengguna mesti mengesahkan dengan token untuk mengakses API.
Nota akhir
- Pastikan Logik Pengesahan Bersih -Mengambil alih Menggunakan Permintaan Borang Untuk Peraturan Kompleks.
- Gunakan sumber API (
php artisan make:resource PostResource
) untuk memformat respons. - Sentiasa mengendalikan kesilapan dengan anggun (contohnya, 404, 422).
- Gunakan versi (contohnya,
/api/v1/posts
) untuk kestabilan jangka panjang.
Itu sahaja. Anda kini mempunyai API REST berfungsi sepenuhnya dengan Laravel. Ia bersih, berskala, dan bersedia untuk kegunaan dunia sebenar.
Atas ialah kandungan terperinci Bagaimana membina API REST dengan Laravel?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

1. 2. Prestasi tinggi memerlukan pergantungan pada cache (redis), pengoptimuman pangkalan data, CDN dan giliran tak segerak; 3. Keselamatan mesti dilakukan dengan penapisan input, perlindungan CSRF, HTTPS, penyulitan kata laluan dan kawalan kebenaran; 4. Pengiklanan pilihan wang, langganan ahli, ganjaran, komisen, pembayaran pengetahuan dan model lain, terasnya adalah untuk memadankan nada komuniti dan keperluan pengguna.

Artikel ini bertujuan untuk menyelesaikan kesilapan umum dalam rangka kerja Laravel di mana parameter penghalaan lulus memadankan kaedah pengawal. Kami akan menerangkan secara terperinci mengapa menulis parameter secara langsung kepada nama kaedah pengawal dalam definisi penghalaan akan mengakibatkan kesilapan "kaedah tidak wujud", dan memberikan sintaks definisi penghalaan yang betul untuk memastikan pengawal dapat menerima dan memproses parameter penghalaan dengan betul. Di samping itu, artikel itu akan meneroka amalan terbaik untuk menggunakan kaedah HttpDelete dalam operasi penghapusan.

Artikel ini bertujuan untuk menyelesaikan cara untuk mengakses sifat -sifat mendalam yang cekap dan selamat yang berkaitan dengan model melalui laluan rentetan apabila data yang dinamik dalam komponen LaravelliveWire. Apabila anda perlu mendapatkan medan tertentu model yang berkaitan berdasarkan rentetan konfigurasi (seperti "user.name"), akses menggunakan sifat objek akan gagal. Artikel ini akan memperkenalkan fungsi penolong data_get Laravel secara terperinci dan memberikan contoh kod untuk menunjukkan cara menggunakannya untuk menyelesaikan masalah ini dengan anggun dan memastikan fleksibiliti dan keteguhan pemerolehan data.

Apabila memilih rangka kerja PHP yang sesuai, anda perlu mempertimbangkan secara komprehensif mengikut keperluan projek: Laravel sesuai untuk pembangunan pesat dan menyediakan enjin template eloquentorm dan bilah, yang mudah untuk operasi pangkalan data dan rendering bentuk dinamik; Symfony lebih fleksibel dan sesuai untuk sistem kompleks; Codeigniter adalah ringan dan sesuai untuk aplikasi mudah dengan keperluan prestasi tinggi. 2. Untuk memastikan ketepatan model AI, kita perlu memulakan dengan latihan data berkualiti tinggi, pemilihan penunjuk penilaian yang munasabah (seperti ketepatan, penarikan balik, nilai F1), penilaian prestasi biasa dan penalaan model, dan memastikan kualiti kod melalui ujian unit dan ujian integrasi, sambil terus memantau data input untuk mencegah data drift. 3. Banyak langkah diperlukan untuk melindungi privasi pengguna: menyulitkan dan menyimpan data sensitif (seperti AES

Terdapat tiga cara utama untuk menetapkan pembolehubah persekitaran dalam PHP: 1. Konfigurasi global melalui php.ini; 2. Melalui pelayan web (seperti setenv Apache atau fastcgi_param of nginx); 3. Gunakan fungsi Putenv () dalam skrip PHP. Antaranya, php.ini sesuai untuk konfigurasi global dan jarang mengubah konfigurasi, konfigurasi pelayan web sesuai untuk senario yang perlu diasingkan, dan putenv () sesuai untuk pembolehubah sementara. Dasar kegigihan termasuk fail konfigurasi (seperti php.ini atau konfigurasi pelayan web), fail .Env dimuatkan dengan perpustakaan dotenv, dan suntikan dinamik pembolehubah dalam proses CI/CD. Maklumat sensitif pengurusan keselamatan harus dielakkan dengan keras, dan disyorkan untuk digunakan.

Untuk membolehkan bekas PHP menyokong pembinaan automatik, terasnya terletak pada mengkonfigurasi proses integrasi berterusan (CI). 1. Gunakan Dockerfile untuk menentukan persekitaran PHP, termasuk imej asas, pemasangan lanjutan, pengurusan ketergantungan dan tetapan kebenaran; 2. Konfigurasi alat CI/CD seperti Gitlabci, dan tentukan peringkat binaan, ujian dan penempatan melalui fail .gitlab-ci.yml untuk mencapai pembinaan, pengujian dan penggunaan automatik; 3. Mengintegrasikan kerangka ujian seperti PHPUnit untuk memastikan ujian secara automatik dijalankan selepas perubahan kod; 4. Gunakan strategi penempatan automatik seperti Kubernet untuk menentukan konfigurasi penempatan melalui fail penyebaran.yaml; 5. Mengoptimumkan Dockerfile dan mengamalkan pembinaan pelbagai peringkat

Artikel ini secara mendalam meneroka penghantaran parameter penghalaan yang betul dan mekanisme pemadanan kaedah pengawal dalam rangka kerja Laravel. Sebagai tindak balas kepada "kaedah tidak wujud" biasa yang disebabkan oleh penulisan parameter penghalaan secara langsung kepada nama kaedah pengawal, artikel itu menghuraikan cara yang betul untuk menentukan penghalaan, iaitu, mengisytiharkan parameter dalam URI dan menerima mereka sebagai parameter bebas dalam kaedah pengawal. Pada masa yang sama, artikel ini juga menyediakan contoh kod dan cadangan mengenai amalan terbaik untuk kaedah HTTP, yang bertujuan untuk membantu pemaju membina aplikasi Laravel yang lebih mantap dan tenang.

Artikel ini membincangkan postur pemindahan parameter yang betul kaedah pengawal dalam penghalaan Laravel secara mendalam. Sebagai tindak balas kepada kesilapan biasa yang disebabkan oleh menulis parameter penghalaan secara langsung kepada nama kaedah pengawal, sintaks definisi penghalaan yang betul dijelaskan secara terperinci, dan mekanisme parameter automatik Laravel mengikat ditekankan. Pada masa yang sama, artikel itu mengesyorkan menggunakan kaedah httpDelete yang lebih selaras dengan spesifikasi yang tenang untuk mengendalikan operasi penghapusan untuk meningkatkan pemeliharaan dan semantik permohonan.
