Cara Membuat Permintaan HTTP di Node.js dengan node-fetch

Cara Membuat Permintaan Http Di Node Js Dengan Node Fetch



Permintaan HTTP sangat penting dan dibuat untuk mengambil informasi dari URL secara global, misalnya memanggil situs web, dll. Pendekatan ini berlaku ketika aplikasi web perlu menjalin komunikasi dengan server web untuk mengakses sumber daya. Misalnya, mengambil atau memposting data ke server web atau API.

Dalam JavaScript, ini dapat dilakukan melalui “ jendela.ambil() ' metode. Namun, dalam “ node.js ”, fungsi ini dapat dicapai dengan menggunakan beberapa paket, misalnya pengambilan simpul, dll.

Blog ini menjelaskan area konten berikut:







Apa itu 'pengambilan simpul'?

pengambilan simpul ” berhubungan dengan modul ringan yang membuat API pengambilan dapat diakses oleh node.js. Modul ini juga memungkinkan pengguna untuk menggunakan “ mengambil() ” Metode di node.js yang sebagian besar mirip dengan JavaScript “ jendela.ambil() ' metode.



Sintaks (metode pengambilan ())



mengambil ( url [ , pilihan ] ) ;

Dalam sintaks ini:





  • url ” mengacu pada URL sumber daya yang perlu diambil/diambil.
  • pilihan Parameter ” diperlukan ketika ada kebutuhan untuk menggunakan metode “fetch()” selain membuat “ MENDAPATKAN ' meminta.

Nilai Pengembalian

Fungsi ini mengambil objek Respon yang berisi informasi mengenai respons HTTP sebagai berikut:



  • teks: Mengambil badan respons dalam bentuk string.
  • header: Mengembalikan objek yang terdiri dari penangan respons.
  • json(): Mengurai isi respons dalam objek JSON.
  • teks status/status: Berisi informasi mengenai kode status HTTP.
  • Oke: Memberikan “ BENAR ” jika statusnya adalah kode status 2xx.

Prasyarat untuk Menggunakan pengambilan simpul

Berikut ini adalah prasyarat yang harus diperhatikan sebelum memulai dengan “ pengambilan simpul ”:

  • Diinstal minimal atau terbaru dari versi 17.5.
  • Pengetahuan dasar tentang JavaScript.

Bagaimana Cara Membuat Permintaan HTTP di node.js dengan node-fetch?

Membuat permintaan HTTP adalah prosedur asinkron karena menerima respons yang diminta memerlukan waktu. Hal ini sedemikian rupa sehingga ada dua metodologi untuk memanfaatkan prosedur asynchronous. Yang pertama adalah pengguna dapat menunggu respons dan kemudian melanjutkan dengan kodenya. Yang lainnya adalah mengeksekusi kode secara paralel.

Bagaimana Memulai dengan pengambilan simpul?

Sebelum memulai atau menginstal “ pengambilan simpul modul ”, inisialisasi proyek simpul dengan bantuan perintah yang diberikan di bawah ini:

npm init - Dan

Mengeksekusi perintah ini akan menciptakan “ paket.json ” file di direktori saat ini, sebagai berikut:

Sekarang, instal “ pengambilan simpul modul ” menggunakan cmdlet berikut:

simpul instalasi npm - mengambil

Namun, untuk menginstal versi modul target, gunakan perintah berikut:

simpul instalasi npm - mengambil@ 2.0

Dalam hal ini, “ 2.0 ” versi modul akan diinstal.

Catatan: Sebelum melanjutkan dengan contoh, buatlah “ indeks.mjs ” file di ruang kerja yang akan digunakan untuk menerapkan fungsionalitas.

Contoh 1: Kirim Dapatkan Permintaan Melalui pengambilan simpul

pengambilan simpul Modul ” dapat digunakan untuk mendapatkan teks dari server web atau data melalui Rest API.

Contoh kode di bawah ini ditulis dalam “ indeks.mjs ” file membuat permintaan Dapatkan sederhana ke beranda YouTube:

impor mengambil dari 'pengambilan simpul' ;

mengambil ( 'https://youtube.com' )

. Kemudian ( res => res. teks ( ) )

. Kemudian ( teks => menghibur. catatan ( teks ) ) ;

Di baris kode ini:

  • Muat “ pengambilan simpul ” modul dan mengambil beranda YouTube melalui URL tertentu yang menjadi tujuan permintaan HTTP dibuat.
  • Setelah itu, rantai “ Kemudian() ” metode untuk menangani respons dan data dari permintaan yang dibuat.
  • Metode “then()” sebelumnya menunjukkan menunggu untuk mendapatkan respons dari server YouTube dan mengubahnya ke format teks.
  • Metode “then()” yang terakhir menandakan penantian hasil transformasi sebelumnya dan menampilkannya di konsol.

Keluaran

Sekarang, jalankan kode melalui cmdlet berikut:

indeks simpul. mjs

Menjalankan perintah di atas akan menghasilkan pengambilan seluruh markup HTML beranda YouTube yang ditampilkan di konsol:

Contoh 2: Ambil Data JSON Dari Rest API

Contoh ini menggunakan “ pengambilan simpul ” untuk mendapatkan data palsu melalui JSONPlaceholder IstirahatAPI. Sedemikian rupa sehingga “ mengambil() ” Metode terdiri dari URL server dan menunggu tanggapan:

impor mengambil dari 'pengambilan simpul' ;

mengambil ( 'https://jsonplaceholder.typicode.com/users' )

. Kemudian ( res => res. json ( ) )

. Kemudian ( json => {

menghibur. catatan ( 'Pengguna Array Pertama ->' ) ;

menghibur. catatan ( json [ 0 ] ) ;

menghibur. catatan ( 'Nama Pengguna Array Pertama ->' ) ;

menghibur. catatan ( json [ 0 ] . nama ) ;

} )

Menurut blok kode ini, lakukan langkah-langkah berikut:

  • Badan HTTPS terdiri dari data berformat JSON yang memiliki data pengguna.
  • Setelah itu, “ json() ” Fungsi diterapkan untuk memanggil entri individual dan nilai yang sesuai.

Keluaran

Terapkan cmdlet yang disebutkan di bawah ini untuk mengeksekusi kode:

indeks simpul. mjs

Contoh 3: Posting Permintaan Melalui pengambilan simpul

pengambilan simpul Modul ” juga dapat digunakan untuk mengirim permintaan alih-alih mengambilnya. Hal ini dapat dicapai melalui “ mengambil() ” metode yang menyertakan parameter tambahan untuk membuat permintaan POST ke server.

Ada beberapa pilihan yang dapat dialokasikan dengan parameter ini. Namun, dalam kasus ini, “ metode ', ' tubuh ' Dan ' header ' akan digunakan. Berikut penjelasan masing-masing opsi tersebut:

  • metode Opsi ” mengatur jenis permintaan HTTP, yaitu “POST” dalam skenario ini.
  • tubuh ” opsi terdiri dari isi permintaan.
  • tajuk Opsi ” berisi semua tajuk yang diperlukan yaitu, “ Jenis konten ” dalam skenario ini.

Sekarang, lanjutkan ke implementasi praktis pengiriman permintaan postingan dengan menambahkan item baru ke “ semua ”. Hal ini dilakukan dengan menambahkan item baru ke daftar yang memiliki ID pengguna sebagai “476”:

impor mengambil dari 'pengambilan simpul' ;

biarkan semuanya = {

identitas pengguna : 476 ,

lokasi : 'Ini adalah petunjuk Linux' ,

lengkap : PALSU

} ;

mengambil ( 'https://jsonplaceholder.typicode.com/todos' , {

metode : 'POS' ,

tubuh : JSON. merangkai ( semua ) ,

header : { 'Jenis konten' : 'aplikasi/json' }

} ) . Kemudian ( res => res. json ( ) )

. Kemudian ( json => menghibur. catatan ( json ) ) ;

Dalam kode ini:

  • Pertama-tama, buat objek rencana dan ubah menjadi JSON sambil menambahkannya ke badan.
  • Sekarang, tentukan juga URL dengan opsi yang diperlukan sebagai “ mengambil() ” parameter opsional metode.
  • Setelah itu, terapkan “ JSON.stringify() ” metode untuk mengubah objek menjadi string yang diformat (JSON) sebelum mengirim/mentransmisikannya ke server web.
  • Ke depan, terapkan gabungan “ Kemudian() ” metode untuk mengambil data dengan menunggu respons, mengubahnya menjadi JSON, dan masuk ke konsol.

Keluaran

Jalankan perintah yang disediakan di bawah ini untuk menjalankan kode:

indeks simpul. mjs

Apa Kode Status HTTP?

Sebelum melanjutkan ke contoh berikutnya, pastikan bahwa jika responsnya terdiri dari “ 3xx ” kode status, langkah tambahan perlu diambil oleh klien. Demikian pula, “ 4xx ” kode mewakili permintaan yang tidak valid dan “ 5xx ” Kode sesuai dengan kesalahan server.

Catatan: menangkap() Fungsi ” tidak dapat menangani kasus-kasus yang dibahas di atas karena komunikasi server berjalan dengan cara yang efisien. Oleh karena itu, pendekatan yang efektif untuk memastikan bahwa permintaan yang gagal mengembalikan kesalahan adalah dengan mendefinisikan fungsi yang menganalisis status HTTP dari respons server.

Contoh 4: Mengatasi Pengecualian dan Keterbatasan

Mungkin ada beberapa batasan atau pengecualian pada permintaan yang dikirim, misalnya masalah dengan Internet, “ mengambil() ” batasan fungsi, dll. Pengecualian ini dapat ditangani dengan menambahkan “ menangkap() ' fungsi:

fungsi menganalisisStatus ( X ) {

jika ( X. Oke ) {

kembali X

} kalau tidak {

melemparkan baru Kesalahan ( `Status HTTP sehubungan dengan respons -> $ { X. status } ( $ { X. statusTeks } ) ` ) ;

}

}

mengambil ( 'https://jsonplaceholder.typicode.com/MissingResource' )

. Kemudian ( menganalisisStatus )

. Kemudian ( X => X. json ( ) )

. Kemudian ( json => menghibur. catatan ( json ) )

. menangkap ( berbuat salah => menghibur. catatan ( berbuat salah ) ) ;

Dalam cuplikan kode ini:

  • Pertama, tentukan fungsi yang memiliki parameter yang dinyatakan sebelum mengurai respons untuk mengatasi keterbatasan yang dihadapi.
  • Sekarang, sertakan “ jika/lainnya ” pernyataan untuk menampilkan kesalahan yang dihadapi atau batasan khusus.
  • Setelah itu, terapkan cara yang sama “ mengambil() ” dan metode “then()” terkait untuk mengambil data dengan menunggu respons, mengubahnya menjadi JSON, dan masuk ke konsol.
  • Terakhir, pengecualian runtime dapat diatasi dengan menempatkan tombol “ menangkap() ” metode di akhir rantai janji.

Keluaran

Terakhir, jalankan cmdlet yang diberikan di bawah ini untuk menjalankan kode dan menampilkan pengecualian yang dihadapi:

indeks simpul. mjs

Kasus Penggunaan Lainnya dari 'pengambilan simpul'

pengambilan simpul ”bisa juga digunakan untuk membuat” Permintaan API ' atau ' Pengikisan Web ”. Mari kita bahas kasus penggunaan ini secara mendetail.

Pemanfaatan node-fetch untuk Membuat Permintaan API

API dapat diperlukan dalam beberapa skenario untuk mengambil data target melalui sumber back-end. Permintaan HTTP dapat memiliki banyak metode otentikasi seperti memanfaatkan kunci API dimana penyedia API menyediakan kunci yang dibatasi untuk pengguna saja. Pendekatan lain untuk melindungi API dapat dilakukan melalui “ Otentikasi Dasar ” di mana header perlu dikirim untuk memanggil API.

Berikut ini adalah demonstrasi pendekatan yang terakhir yaitu, “Otentikasi Dasar” dalam permintaan pos dengan bantuan “ mengambil() ' metode:

( asinkron ( ) => {

konstanta X = menunggu pengambilan ( 'http://httpbin.org/post' , {

metode : 'POS' ,

header : {

'Otorisasi' : `Dasar $ { kawan ( 'kata sandi masuk' ) } `

} ,

tubuh : JSON. merangkai ( {

'kunci' : 'nilai'

} )

} ) ;

konstanta hasil = tunggu x. teks ( ) ;

menghibur. catatan ( hasil ) ;

} ) ( ) ;

Dalam demonstrasi di atas, header dikirim dengan “ base64 ” string format yang disandikan “ kata sandi masuk ”.

Pemanfaatan node-fetch untuk Web Scraping

Pengikisan Web ” mengacu pada teknik di mana data/konten diambil dari situs dan diurai. Penguraian ini dicapai melalui “ ceria ' perpustakaan.

Di bawah ini adalah demonstrasi mengambil judul halaman melalui “ mengambil() ” metode dan “ ceria ' perpustakaan:

konstanta lib = memerlukan ( 'bersorak' ) ;

( asinkron ( ) => {

konstanta X = menunggu pengambilan ( 'https://linuxhint.com/' ) ;

konstanta Dan = tunggu x. teks ( ) ;

konstanta $ = lib. memuat ( Dan ) ;

menghibur. catatan ( $ ( 'judul' ) . Pertama ( ) . teks ( ) ) ;

} ) ( ) ;

Contoh ini mengambil ubin “ Linux ” judul situs.

Kesimpulan

Permintaan HTTP di node.js dapat dibuat dengan node-fetch dengan mengirimkan permintaan get, mengambil data JSON dari REST API, atau mengirimkan permintaan posting. Selain itu, pengecualian dan pembatasan dapat ditangani secara efektif melalui “ menangkap() ' fungsi.