REST API dan Seni Binanya
Pengenalan
Dalam dunia pembangunan web hari ini, API (Antara Muka Pengaturcaraan Aplikasi) memainkan peranan penting dalam membolehkan komunikasi antara sistem perisian yang berbeza. Salah satu jenis API yang paling banyak digunakan ialah API REST, yang bermaksud Pemindahan Negeri Perwakilan. API REST telah menjadi standard untuk membina perkhidmatan web yang boleh skala, boleh diselenggara dan cekap. Dalam blog ini, kami akan menyelami lebih mendalam tentang apa itu REST API, prinsip, seni bina, komponen dan cara mereka bentuk serta melaksanakannya dengan berkesan.
Apakah itu REST API?
REST (Pemindahan Negeri Perwakilan) ialah gaya seni bina untuk mereka bentuk aplikasi rangkaian. Ia bergantung pada model komunikasi pelanggan-pelayan tanpa kewarganegaraan dan berdasarkan kaedah HTTP standard. API REST membenarkan aplikasi yang berbeza untuk berkomunikasi melalui internet menggunakan set konvensyen ringkas atau kita boleh katakan peraturan.
API REST ialah antara muka yang membolehkan pelanggan (seperti web atau aplikasi mudah alih seperti penyemak imbas atau telefon kami) berinteraksi dengan pelayan dengan menghantar permintaan HTTP dan menerima respons HTTP. Pelayan menyediakan akses kepada sumber, yang boleh berupa apa sahaja daripada profil pengguna kepada imej atau catatan blog.
Prinsip Utama REHAT
Untuk dianggap RESTful, API mesti mempunyai enam prinsip berikut:
- Seni Bina Pelayan-Pelanggan: Pelanggan dan pelayan hendaklah bebas antara satu sama lain. Pelanggan bertanggungjawab untuk antara muka pengguna dan pengalaman pengguna, manakala pelayan mengendalikan logik bahagian belakang, storan data dan pemprosesan.
- Ketiadaan kenegaraan: Setiap permintaan daripada pelanggan kepada pelayan mesti mengandungi semua maklumat yang diperlukan untuk memahami dan memproses permintaan tersebut. Pelayan tidak menyimpan sebarang maklumat pelanggan antara permintaan. Ini menjadikan reka bentuk pelayan dan meningkatkan kebolehskalaan.
- Kebolehcache: Respons daripada pelayan mesti ditakrifkan dengan jelas sebagai boleh cache atau tidak boleh cache. Jika respons boleh dicache, pelanggan boleh menggunakan semula data respons untuk permintaan masa hadapan, mengurangkan beban pada pelayan dan meningkatkan prestasi.
- Antara Muka Seragam: REST API mesti menyediakan cara yang konsisten dan standard untuk berinteraksi dengan sumber. Ini dicapai melalui empat sub-prinsip: - Pengenalpastian Sumber: Sumber dikenal pasti menggunakan URI (Uniform Resource Identifiers). - Manipulasi Sumber Melalui Perwakilan: Pelanggan berinteraksi dengan sumber dengan menghantar perwakilan (cth., JSON, XML) dalam permintaan. - Mesej deskriptif kendiri: Setiap permintaan dan respons mesti mengandungi maklumat yang mencukupi untuk menerangkan cara memproses mesej. - Hypermedia sebagai Enjin Keadaan Aplikasi (HATEOAS): Pelanggan harus menavigasi API secara dinamik menggunakan hiperpautan yang disediakan dalam respons.
- Sistem Berlapis: Seni bina harus membenarkan penggunaan lapisan perantara antara klien dan pelayan, seperti caching, pengimbangan beban dan lapisan keselamatan, tanpa pelanggan menyedari lapisan ini.
- Kod atas Permintaan (Pilihan): Pelayan boleh melanjutkan fungsi klien dengan menghantar kod boleh laku, seperti JavaScript, untuk dilaksanakan pada bahagian klien. Ini adalah kekangan pilihan dalam REST.
Seni Bina REST API
Seni bina API REST terdiri daripada beberapa komponen utama yang bekerjasama untuk mewujudkan komunikasi antara pelanggan dan pelayan:
Sumber: Sumber ialah konsep teras API REST. Ia mewakili data atau objek yang API menyediakan akses, seperti pengguna, produk, pesanan, dll. Setiap sumber dikenal pasti oleh URI unik.
Kaedah HTTP: REST API menggunakan kaedah HTTP standard untuk melaksanakan operasi CRUD (Buat, Baca, Kemas Kini, Padam) pada sumber:
- DAPATKAN: Tarik data daripada sumber.
- POST: Buat perubahan data baharu dalam sumber(DB).
- PUT: Kemas kini rekod sedia ada dalam data(DB) anda.
- PADAM: Alih keluar data khusus daripada DB.
- PATCH: Kemas kini sebahagian data sedia ada.
- PILIHAN: Dapatkan semula kaedah HTTP yang disokong untuk sumber.Kod Status HTTP: REST API menggunakan kod status HTTP standard untuk menunjukkan hasil permintaan. Kod status biasa termasuk:
- 200 OK: Permintaan berjaya.
- 201 Dicipta: Sumber baharu telah berjaya dibuat.
- 204 Tiada Kandungan: Permintaan berjaya, tetapi tiada kandungan untuk dikembalikan.
- 400 Permintaan Buruk: Permintaan itu salah bentuk atau tidak sah.
- 401 Tanpa Kebenaran: Pelanggan mesti mengesahkan untuk mengakses sumber.
- 404 Tidak Ditemui: Sumber yang diminta tidak ditemui.
- 500 Ralat Pelayan Dalaman: Ralat yang tidak dijangka berlaku pada pelayan.Format Perwakilan: REST API menyokong pelbagai format perwakilan untuk pertukaran data, termasuk JSON (JavaScript Object Notation), XML (eXtensible Markup Language) dan HTML. JSON ialah format yang paling biasa digunakan kerana kesederhanaan dan keserasiannya dengan JavaScript.
Titik Tamat: Titik akhir ialah URL yang menentukan tempat sumber tertentu boleh diakses daripada pelayan. Setiap titik akhir sepadan dengan sumber tertentu dan biasanya direka bentuk menggunakan kata nama dan bukannya kata kerja (cth., /users, /products).
Merancang API RESTful
Merancang API RESTful melibatkan beberapa langkah untuk memastikan ia mematuhi prinsip REST dan memberikan pengalaman yang lancar untuk pelanggan. Berikut ialah beberapa amalan terbaik untuk mereka bentuk API REST:
Gunakan Kata Nama untuk Titik Akhir: Titik tamat hendaklah dinamakan sempena sumber (kata nama) dan bukannya tindakan (kata kerja). Contohnya, gunakan /users untuk mewakili koleksi pengguna dan bukannya /getUsers.
Gunakan Kaedah HTTP Sewajarnya: Gunakan kaedah HTTP yang betul untuk setiap operasi. Contohnya, gunakan GET untuk mendapatkan data, POST untuk membuat data, PUT untuk mengemas kini data dan PADAM untuk mengalih keluar data.
Laksanakan Penapisan, Pengisihan dan Penomboran: Untuk titik akhir yang mengembalikan senarai sumber, laksanakan penapisan, pengisihan dan penomboran untuk meningkatkan prestasi dan memberikan lebih kawalan kepada pelanggan. Gunakan parameter pertanyaan seperti ?sort=name, ?page=2, atau ?limit=10 untuk mencapai ini.
Versi API Anda: Sentiasa versikan API anda untuk mengendalikan perubahan tanpa melanggar pelanggan sedia ada. Sertakan nombor versi dalam URL (cth., /api/v1/users) atau dalam pengepala.
Sediakan Kod Status HTTP Bermakna: Kembalikan kod status HTTP yang sesuai untuk menunjukkan hasil permintaan. Elakkan menggunakan 200 OK untuk setiap respons.
Gunakan Hipermedia (HATEOAS): Sertakan pautan dalam respons untuk membolehkan pelanggan menavigasi API secara dinamik tanpa URL pengekodan keras.
Pastikan Keselamatan: Lindungi API anda menggunakan HTTPS untuk menyulitkan data dalam transit. Laksanakan pengesahan (cth., OAuth, JWT) dan Kebenaran untuk mengawal akses kepada sumber.
Kendalikan Ralat Dengan Anggun: Sediakan mesej ralat yang bermakna dan kod status HTTP untuk membantu pelanggan memahami masalah yang berlaku. Buat format ralat boleh guna semula dengan butiran seperti kod ralat, mesej dan penyelesaian yang mungkin.
Contoh Reka Bentuk API REST
Mari kita pertimbangkan contoh REST API mudah untuk menguruskan koleksi buku:
- Titik tamat: /api/v1/books
- DAPATKAN /api/v1/books: Dapatkan senarai semua buku daripada db. - POST /api/v1/books: Buat buku baharu dalam db.
- Titik tamat: /api/v1/books/{id}
- DAPATKAN /api/v1/books/{id}: Kembalikan buku tertentu mengikut ID. - PUT /api/v1/books/{id}: Kemas kini buku tertentu mengikut ID. - DELETE /api/v1/books/{id}: Padamkan buku tertentu dengan ID.
- Contoh Pengendalian Ralat:
- Jika pelanggan meminta buku yang tidak wujud: - Maklum balas: 404 Tidak Ditemui - Badan: Badan akan kelihatan seperti ini
Melaksanakan API REST
Untuk melaksanakan API REST, anda boleh menggunakan pelbagai bahasa pengaturcaraan dan rangka kerja. Berikut ialah contoh menggunakan Node.js dengan Express.js:
Atas ialah kandungan terperinci REST API dan Seni Binanya. 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)

Skop JavaScript menentukan skop kebolehcapaian pembolehubah, yang dibahagikan kepada skop global, fungsi dan tahap blok; Konteks menentukan arah ini dan bergantung kepada kaedah panggilan fungsi. 1. Skop termasuk skop global (boleh diakses di mana sahaja), skop fungsi (hanya sah dalam fungsi), dan skop peringkat blok (biarkan dan const sah dalam {}). 2. Konteks pelaksanaan mengandungi objek pembolehubah, rantaian skop dan nilai -nilai ini. Ini menunjukkan kepada global atau tidak ditentukan dalam fungsi biasa, kaedah panggilan kaedah ke objek panggilan, pembina menunjuk ke objek baru, dan juga boleh ditentukan secara jelas oleh panggilan/memohon/mengikat. 3. Penutupan merujuk kepada fungsi mengakses dan mengingati pembolehubah skop luaran. Mereka sering digunakan untuk enkapsulasi dan cache, tetapi boleh menyebabkan

COMPOSISAPI dalam VUE3 lebih sesuai untuk logik dan jenis derivasi yang kompleks, dan OptionsAPI sesuai untuk senario dan pemula yang mudah; 1. Optionsapi menganjurkan kod mengikut pilihan seperti data dan kaedah, dan mempunyai struktur yang jelas tetapi komponen kompleks dipecah -pecah; 2. CompositionAPI menggunakan persediaan untuk menumpukan logik yang berkaitan, yang kondusif untuk penyelenggaraan dan penggunaan semula; 3. Compositionapi menyedari penggunaan semula logik bebas konflik dan parameternya melalui fungsi kompos yang lebih baik daripada Mixin; 4. CompositionAPI mempunyai sokongan yang lebih baik untuk typescript dan derivasi jenis yang lebih tepat; 5. Tidak terdapat perbezaan yang signifikan dalam jumlah prestasi dan pembungkusan kedua -duanya; 6.

Terdapat dua kaedah teras untuk mendapatkan nilai butang radio yang dipilih. 1. Gunakan QuerySelector untuk mendapatkan item yang dipilih secara langsung, dan gunakan input [NAME = "NAMA-NAMA ANDA"]: Pemilih yang diperiksa untuk mendapatkan elemen yang dipilih dan membaca atribut nilainya. Ia sesuai untuk pelayar moden dan mempunyai kod ringkas; 2. Gunakan Document.GetElementsByName untuk melintasi dan mencari radio yang diperiksa pertama melalui nodelist gelung dan mendapatkan nilainya, yang sesuai untuk senario yang serasi dengan pelayar lama atau memerlukan kawalan manual proses; Di samping itu, anda perlu memberi perhatian kepada ejaan atribut nama, mengendalikan situasi yang tidak dipilih, dan pemuatan kandungan dinamik

Terdapat perbezaan penting antara pekerja web JavaScript dan Javathreads dalam pemprosesan serentak. 1. JavaScript mengamalkan model tunggal-thread. WebWorkers adalah benang bebas yang disediakan oleh penyemak imbas. Ia sesuai untuk melaksanakan tugas-tugas yang memakan masa yang tidak menghalang UI, tetapi tidak dapat mengendalikan DOM; 2. Java menyokong multithreading sebenar dari tahap bahasa, yang dibuat melalui kelas thread, sesuai untuk logik serentak dan pemprosesan sisi serentak; 3. WebWorkers menggunakan postmessage () untuk berkomunikasi dengan benang utama, yang sangat selamat dan terpencil; Benang Java boleh berkongsi ingatan, jadi isu penyegerakan perlu diberi perhatian; 4. Pekerja web lebih sesuai untuk pengkomputeran selari depan, seperti pemprosesan imej, dan

Pemutus jenis adalah tingkah laku secara automatik menukar satu jenis nilai kepada jenis lain dalam JavaScript. Senario biasa termasuk: 1. Apabila menggunakan pengendali, jika satu sisi adalah rentetan, sisi lain juga akan ditukar kepada rentetan, seperti '5' 5. Hasilnya ialah "55"; 2. 3. Null mengambil bahagian dalam operasi berangka dan akan ditukar kepada 0, dan undefined akan ditukar kepada NAN; 4. Masalah yang disebabkan oleh penukaran tersirat boleh dielakkan melalui fungsi penukaran eksplisit seperti nombor (), rentetan (), dan boolean (). Menguasai peraturan ini membantu

Tarikh format dalam JavaScript boleh dilaksanakan melalui kaedah asli atau perpustakaan pihak ketiga. 1. Gunakan Jahitan Objek Tarikh Asli: Dapatkan bahagian tarikh melalui getfuleear, getmonth, getdate dan kaedah lain, dan secara manual menyambungkannya ke yyyy-mm-dd dan format lain, yang sesuai untuk keperluan ringan dan tidak bergantung pada perpustakaan pihak ketiga; 2. Gunakan kaedah tolocaledatestring: anda boleh output seperti format mm/dd/yyyy mengikut tabiat tempatan, menyokong pelbagai bahasa, tetapi formatnya mungkin tidak konsisten kerana persekitaran yang berbeza; 3. Gunakan perpustakaan pihak ketiga seperti hari.js atau tarikh-FNS: Menyediakan sintaks ringkas dan fungsi yang kaya, sesuai untuk operasi yang kerap atau apabila kelanjutan diperlukan, seperti dayjs ()

Memulakan projek dan buat pakej.json; 2. Buat skrip kemasukan index.js dengan shebang; 3. Daftar perintah melalui medan bin dalam pakej.json; 4. Gunakan Yargs dan perpustakaan lain untuk menghuraikan parameter baris arahan; 5. Gunakan ujian tempatan NPMLink; 6. Tambah bantuan, versi dan pilihan untuk meningkatkan pengalaman; 7. Secara pilihan menerbitkan melalui NPMPublish; 8. Secara pilihan mencapai penyelesaian automatik dengan YARGS; Akhirnya buat alat CLI praktikal melalui struktur yang munasabah dan reka bentuk pengalaman pengguna, tugas automasi lengkap atau mengedarkan widget, dan berakhir dengan ayat lengkap.

Gunakan document.createelement () untuk membuat elemen baru; 2. Sesuaikan elemen melalui textContent, classlist, setAttribute dan kaedah lain; 3. Gunakan kaedah tambahan () atau lebih fleksibel () untuk menambah elemen ke DOM; 4. Secara pilihan menggunakan InsertBefore (), sebelum () dan kaedah lain untuk mengawal kedudukan penyisipan; Proses lengkap adalah untuk membuat → Sesuaikan → Tambah, dan anda boleh mengemas kini kandungan halaman secara dinamik.
