1, analisis pembukaan
Pertama sekali, semua orang harus biasa dengan konsep "Http". Ia tidak berdasarkan bahasa tertentu Ia adalah protokol lapisan aplikasi umum mempunyai butiran pelaksanaan yang berbeza, tetapi ia tetap sama dan ideanya adalah sama
Sebagai persekitaran operasi hos, NodeJS menggunakan JavaScript sebagai bahasa hos Ia juga mempunyai set piawaian sendiri untuk pelaksanaan Dalam artikel ini, kita akan belajar tentang "modul Http" bersama-sama. Tetapi sebagai premis,Saya harap anda boleh membaca API yang disediakan oleh laman web rasmi terlebih dahulu dan mempunyai pra-pemahaman, yang akan menjadi lebih mudah berikut adalah gambaran keseluruhan API bahagian Http:
HTTP
http.STATUS_CODES
http.createServer([requestListener])
http.createClient([port], [host])
Kelas: http.Pelayan
事件 : 'permintaan'
事件: 'sambungan'
事件: 'tutup'
Acara: 'semakTeruskan'
事件: 'sambung'
Acara: 'naik taraf'
Acara: 'clientError'
server.listen(port, [nama hos], [backlog], [panggilan balik])
server.listen(path, [panggilan balik])
server.listen(mengendalikan, [panggilan balik])
server.close([panggilan balik])
server.maxHeadersCount
server.setTimeout(msecs, callback)
pelayan.masa tamat
Kelas: http.ServerResponse
事件: 'tutup'
respons.writeContinue()
response.writeHead(statusCode, [reasonFrasa], [header])
response.setTimeout(msecs, callback)
respons.statusCode
response.setHeader(nama, nilai)
respons.headers Dihantar
respon.sendDate
response.getHeader(nama)
response.removeHeader(nama)
response.write(chunk, [encoding])
response.addTrailer(headers)
response.end([data], [encoding])
http.request(pilihan, panggil balik)
http.get(pilihan, panggil balik)
Kelas: http.Ejen
Ejen baharu([pilihan])
agent.maxSockets
agent.maxFreeSockets
ejen.soket
agent.freeSockets
ejen.permintaan
ejen.musnah()
agent.getName(pilihan)
http.globalAgent
Kelas: http.ClientRequest
'Respons' acara
Acara: 'soket'
事件: 'sambung'
Acara: 'naik taraf'
Acara: 'teruskan'
request.write(chunk, [encoding])
request.end([data], [pengekodan])
request.abort()
request.setTimeout(masa tamat, [panggilan balik])
request.setNoDelay([noDelay])
request.setSocketKeepAlive([enable], [initialDelay])
http.IncomingMessage
事件: 'tutup'
mesej.httpVersion
message.headers
mesej.rawHeaders
mesej.treler
mesej.rawTrailer
message.setTimeout(msecs, callback)
mesej.kaedah
message.url
message.statusCode
mesej.soket
让我们先从一个简单例子开始,创建一个叫server.js的文件,并写入以下代码>:
var http = memerlukan('http') ;
pelayan var = http.createServer(function(req,res){
res.writeHeader(200,{
'Content-Type' : 'text/plain;charset=utf-8' // Tambah charset=utf-8
}) ;
res.end("Hello, Beruang Besar!") ;
}) ;
server.listen(8888) ;
console.log("Pelayan http berjalan pada port 8888 ...") ;
(node server.js) Berikut ialah keputusannya:
2. Contoh analisis terperinci
Lihat contoh kecil ini secara terperinci:
(Baris 1): Perkenalkan modul "http" yang disertakan dengan NodeJS melalui "require" dan berikannya kepada pembolehubah http.
(2 baris): Panggil fungsi yang disediakan oleh modul http: "createServer". Fungsi ini akan mengembalikan objek pelayan web baharu.
Parameter "requestListener" ialah fungsi yang akan ditambahkan secara automatik pada baris gilir mendengar acara "permintaan".
Apabila permintaan datang, Event-Loop akan meletakkan fungsi panggil balik Listener ke dalam baris gilir pelaksanaan, dan semua kod dalam nod akan dikeluarkan daripada baris gilir pelaksanaan satu demi satu untuk pelaksanaan.
Pelaksanaan ini semua dilakukan pada utas kerja (Gelung Peristiwa itu sendiri boleh dianggap berada dalam utas bebas. Kami biasanya tidak menyebut utas ini, tetapi memanggil nod sebagai persekitaran pelaksanaan satu utas),
Semua panggilan balik dijalankan pada urutan pekerja.
Mari kita lihat fungsi panggil balik "requestListener" sekali lagi, yang menyediakan dua parameter (permintaan, respons),
Dipecat setiap kali permintaan diterima. Ambil perhatian bahawa setiap sambungan mungkin mempunyai berbilang permintaan (dalam sambungan kekal hidup).
"permintaan" ialah contoh http.IncomingMessage. "response" ialah contoh http.ServerResponse.
Objek permintaan http ialah strim boleh dibaca dan objek tindak balas http ialah strim boleh tulis.
Objek "IncomingMessage" dicipta oleh http.Server atau http.ClientRequest,
Dan diluluskan sebagai parameter pertama kepada peristiwa "permintaan" dan "tindak balas" masing-masing.
Ia juga boleh digunakan untuk mengakses status respons, pengepala dan data.
Ia melaksanakan antara muka "Strim" dan acara, kaedah dan sifat tambahan berikut. (Rujuk API untuk butiran).
(3 baris): "writeHeader", gunakan fungsi "response.writeHead()" untuk menghantar status Http 200 dan jenis kandungan pengepala Http.
Balas pengepala respons kepada permintaan. "statusCode" ialah kod status HTTP tiga digit, seperti 404. Parameter terakhir, "pengepala", ialah kandungan pengepala respons.
Berikan saya contoh:
var body = 'hello world' ;
response.writeHead(200, {
'Panjang Kandungan': panjang badan,
'Jenis-Kandungan': 'teks/biasa'
}) ;
Nota: Panjang Kandungan dikira dalam bait, bukan aksara.
Sebab untuk contoh sebelumnya ialah rentetan "Hello World!" hanya mengandungi aksara bait tunggal.
Jika badan mengandungi aksara berbilang bait yang dikodkan, anda harus menggunakan Buffer.byteLength() untuk menentukan bilangan bait rentetan dalam kes pengekodan aksara berbilang bait.
Perlu dijelaskan dengan lebih lanjut bahawa Node tidak menyemak sama ada atribut Content-Lenth sepadan dengan panjang badan yang dihantar.
statusCode ialah kod status HTTP tiga digit, contohnya: "404". Perkara yang saya ingin bincangkan di sini ialah "http.STATUS_CODES", yang mengandungi koleksi dan penerangan ringkas semua kod status respons "Http" standard.
Berikut ialah rujukan kod sumber:
var STATUS_CODES = eksport.STATUS_CODES = {
100 : 'Teruskan',
101 : 'Protokol Penukaran',
102 : 'Pemprosesan', // RFC 2518, dilupuskan oleh RFC 4918
200 : 'OK',
201 : 'Dicipta',
202 : 'Diterima',
203 : 'Maklumat Bukan Berautoriti',
204 : 'Tiada Kandungan',
205 : 'Tetapkan Semula Kandungan',
206 : 'Kandungan Separa',
207 : 'Berbilang Status', // RFC 4918
300 : 'Pelbagai Pilihan',
301 : 'Berpindah Secara Kekal',
302 : 'Berpindah Sementara',
303 : 'Lihat Lain',
304 : 'Tidak Diubah Suai',
305 : 'Gunakan Proksi',
307 : 'Ubah Hala Sementara',
400 : 'Permintaan Buruk',
401 : 'Tidak dibenarkan',
402 : 'Pembayaran Diperlukan',
403 : 'Dilarang',
404 : 'Tidak Ditemui',
405 : 'Kaedah Tidak Dibenarkan',
406 : 'Tidak Boleh Diterima',
407 : 'Pengesahan Proksi Diperlukan',
408 : 'Permintaan Tamat Masa',
409 : 'Konflik',
410 : 'Tiada',
411 : 'Panjang Diperlukan',
412 : 'Prasyarat Gagal',
413 : 'Minta Entiti Terlalu Besar',
414 : 'Permintaan-URI Terlalu Besar',
415 : 'Jenis Media Tidak Disokong',
416 : 'Julat Yang Diminta Tidak Memuaskan',
417 : 'Jangkaan Gagal',
418 : 'Saya teko', // RFC 2324
422 : 'Entiti Tidak Boleh Diproses', // RFC 4918
423 : 'Dikunci', // RFC 4918
424 : 'Kebergantungan Gagal', // RFC 4918
425 : 'Koleksi Tidak Tertib', // RFC 4918
426 : 'Naik Taraf Diperlukan', // RFC 2817
500 : 'Ralat Pelayan Dalaman',
501 : 'Tidak Dilaksanakan',
502 : 'Gerbang Buruk',
503 : 'Perkhidmatan Tidak Tersedia',
504 : 'Tamat Masa Gerbang',
505 : 'Versi HTTP tidak disokong',
506 : 'Varian Juga Berunding', // RFC 2295
507 : 'Storan Tidak Mencukupi', // RFC 4918
509 : 'Had Lebar Jalur Melebihi',
510 : 'Tidak Dilanjutkan' // RFC 2774
};
节选自,Nodejs源码 ”http.js“ 143行开始。
其实从客户端应答结果也不难看出:
(6行):”response.end“------当所有的响应报头和报文被发送完成时这个方法将百方法将百页务器会认为这个消息完成了。
每次响应完成之后必须调用该方法。如果指定了参数 “data” ,就相当“于用当”于用当”于用当”于用当”于用当”于用当”于用当”于用当”于用当”于用数后再调用 “response.end()” 。
(8行):”server.listen(8888)“ ------ 服务器用指定的句柄接受连接,绑定在特定的端口>。 🎜细节机制,以便日后高效的开发NodeJS应用。
三,实例除了可以使用"permintaan"对象访问请求头数据外,还能把"permintaan"对象当作一个只据求头数据外,还能把"permintaan"对象当作一个只据讯潕数据。
这是一个"POST"请求的例子:
http.createServer(fungsi (permintaan, respons) {
var body = [];
console.log(request.method) ;
console.log(request.headers) ;
Request.on('data', function (chunk) {
badan. tolak(ketul);
}) ;
Request.on('end', function () {
body = Penampan.concat(badan);
console.log(body.toString()) ;
});
}).dengar(8888) ;
Berikut ialah kandungan data permintaan "Http" yang lengkap.
POST/HTTP/1.1
Ejen Pengguna: curl/7.26.0
Hos: localhost
Terima: */*
Panjang Kandungan: 11
Jenis Kandungan: application/x-www-form-urlencoded
Hello Dunia
Empat, ringkasan
(1), fahami konsep "Http".
(2), mahir menggunakan API berkaitan "Http".
(3) Perhatikan butiran, seperti butiran pemprosesan antara "POST, GET".
(4), pemahaman tentang "requestListener".
(5), menekankan konsep: objek permintaan http ialah aliran yang boleh dibaca, dan objek tindak balas http ialah aliran boleh ditulis.

Vercel是什么?本篇文章带大家了解一下Vercel,并介绍一下在Vercel中部署 Node 服务的方法,希望对大家有所帮助!

gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。

大家都知道 Node.js 是单线程的,却不知它也提供了多进(线)程模块来加速处理一些特殊任务,本文便带领大家了解下 Node.js 的多进(线)程,希望对大家有所帮助!

今天跟大家介绍一个最新开源的 javaScript 运行时:Bun.js。比 Node.js 快三倍,新 JavaScript 运行时 Bun 火了!

在nodejs中,lts是长期支持的意思,是“Long Time Support”的缩写;Node有奇数版本和偶数版本两条发布流程线,当一个奇数版本发布后,最近的一个偶数版本会立即进入LTS维护计划,一直持续18个月,在之后会有12个月的延长维护期,lts期间可以支持“bug fix”变更。

node怎么爬取数据?下面本篇文章给大家分享一个node爬虫实例,聊聊利用node抓取小说章节的方法,希望对大家有所帮助!


Alat AI Hot

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

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

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Dreamweaver Mac版
Alat pembangunan web visual
