Bagaimana untuk memuat turun fail dalam nodejs
Node.js ialah sumber terbuka, masa jalan JavaScript merentas platform yang menjalankan kod JavaScript pada bahagian pelayan dan berjalan dalam persekitaran masa jalan JavaScript. Node.js digunakan secara meluas untuk membangunkan aplikasi web berprestasi tinggi dan boleh skala. Antaranya, muat turun fail adalah salah satu fungsi asas tapak web, dan Node.js juga boleh melaksanakan fungsi muat turun fail dengan mudah. Artikel ini akan memperincikan cara memuat turun fail dalam Node.js.
1 Gunakan modul HTTP untuk memuat turun fail
Dalam Node.js, anda boleh menggunakan modul HTTP untuk memuat turun fail. Modul HTTP ialah salah satu modul teras Node.js dan menyediakan API untuk mencipta klien dan pelayan HTTP.
- Langkah asas untuk memuat turun fail
Untuk memuat turun fail, anda perlu melakukan langkah asas berikut:
(1) Buat permintaan HTTP .
(2) Hantar permintaan HTTP.
(3) Tulis jawapan kepada fail.
Berikut ialah kod asas:
const http = require('http'); const fs = require('fs'); const fileUrl = 'http://example.com/file.pdf'; const filePath = './file.pdf'; const request = http.get(fileUrl, (response) => { const fileStream = fs.createWriteStream(filePath); response.pipe(fileStream); }); request.on('error', (err) => { console.error(`请求下载文件出错: ${err.message}`); }); request.end();
Dalam kod di atas, kami mula-mula membuat permintaan HTTP melalui kaedah get modul HTTP. Dalam fungsi panggil balik permintaan, kami mencipta aliran fail boleh tulis dan menulis respons ke dalam aliran fail melalui paip, dengan itu menulis fail ke cakera.
- Mengendalikan kemajuan muat turun
Untuk muat turun fail yang besar, adalah sangat penting untuk mengetahui kemajuan muat turun. Kita boleh menggunakan pengepala Content-Length
terbina dalam untuk mendapatkan saiz fail dan acara progress
terbina dalam untuk menjejak kemajuan muat turun. Berikut ialah contoh:
const http = require('http'); const fs = require('fs'); const url = 'http://example.com/file.zip'; const filePath = './file.zip'; http.get(url, (response) => { const contentLength = parseInt(response.headers['content-length']); let downloadedLength = 0; response.pipe(fs.createWriteStream(filePath)); response.on('data', (chunk) => { downloadedLength += chunk.length; const percent = downloadedLength / contentLength * 100; console.log(`${percent}% downloaded`); }); response.on('end', () => { console.log('下载完成'); }); }).on('error', (err) => { console.error(`请求下载文件出错: ${err.message}`); });
Dalam kod di atas, kami menggunakan acara data
terbina dalam untuk menjejak kemajuan muat turun dan pengepala Content-Length
untuk mengira peratusan muat turun. Apabila muat turun selesai, kami mengeluarkan mesej "Muat Turun Selesai".
- Mengendalikan ubah hala
Kadangkala, pautan muat turun fail mungkin diubah hala. Kami boleh menyemak sama ada kod status respons ialah 301 atau 302 dan menggunakan pengepala Location
untuk mendapatkan pautan diubah hala. Berikut ialah kod sampel:
const http = require('http'); const https = require('https'); const fs = require('fs'); function downloadFile(url, filePath) { const httpClient = url.startsWith('https') ? https : http; httpClient.get(url, (response) => { const { statusCode } = response; if (statusCode === 301 || statusCode === 302) { console.warn(`文件重定向: ${response.headers.location}`); downloadFile(response.headers.location, filePath); return; } if (statusCode !== 200) { console.error(`请求下载文件出错: 状态码 ${statusCode}`); return; } response.pipe(fs.createWriteStream(filePath)).on('close', () => { console.log('下载完成'); }); }).on('error', (err) => { console.error(`请求下载文件出错: ${err.message}`); }); } const url = 'http://example.com/file.zip'; const filePath = './file.zip'; downloadFile(url, filePath);
Dalam kod di atas, kami menggunakan pembolehubah httpClient
untuk menyemak protokol (http atau https) dan statusCode
untuk menyemak kod status respons. Jika 301 atau 302, keluarkan mesej yang diubah hala dan muat turun semula fail. Jika bukan 200, mesej ralat akan dikeluarkan.
2. Gunakan modul Permintaan untuk memuat turun fail
Selain modul HTTP, terdapat juga beberapa modul pihak ketiga yang popular dalam Node.js yang boleh digunakan untuk memuat turun fail, yang paling popular ialah modul Permintaan. Modul Permintaan ialah klien HTTP yang ringkas, berkuasa dan mesra pengguna yang dicipta oleh Mikeal Rogers.
- Pasang modul Permintaan
Untuk menggunakan modul Permintaan untuk memuat turun fail, anda perlu memasangnya terlebih dahulu. Anda boleh melaksanakan arahan berikut dalam baris arahan untuk memasang:
npm install request --save
- Langkah asas untuk memuat turun fail
Langkah asas untuk memuat turun fail menggunakan modul Request adalah serupa dengan menggunakan modul HTTP. Berikut ialah contoh mudah:
const request = require('request'); const fs = require('fs'); const url = 'http://example.com/file.zip'; const filePath = './file.zip'; request(url) .pipe(fs.createWriteStream(filePath)) .on('finish', () => { console.log('下载完成'); }) .on('error', (err) => { console.error(`请求下载文件出错: ${err.message}`); });
Dalam kod di atas, kami menggunakan kaedah request
untuk membuat permintaan HTTP dan menulis respons kepada aliran fail melalui paip. Apabila muat turun selesai, kami mengeluarkan mesej "Muat Turun Selesai".
- Mengendalikan kemajuan muat turun
Untuk mengendalikan kemajuan muat turun, anda boleh menggunakan objek permintaan yang dikembalikan melalui kaedah request
. Saiz fail boleh diperoleh menggunakan pengepala Content-Length
terbina dalam. Selain itu, modul Permintaan menyediakan acara progress
terbina dalam yang membolehkan kami menjejak kemajuan muat turun. Berikut ialah contoh:
const request = require('request'); const fs = require('fs'); const url = 'http://example.com/file.zip'; const filePath = './file.zip'; const fileStream = fs.createWriteStream(filePath); let downloadedLength = 0; request(url) .on('response', (response) => { const contentLength = parseInt(response.headers['content-length']); console.log(`文件大小: ${(contentLength / 1024 / 1024).toFixed(2)} MB`); response.on('data', (data) => { downloadedLength += data.length; const percent = downloadedLength / contentLength * 100; console.log(`${percent.toFixed(2)}% downloaded`); }); }) .pipe(fileStream) .on('finish', () => { console.log('下载完成'); }) .on('error', (err) => { console.error(`请求下载文件出错: ${err.message}`); });
Dalam kod di atas, kami menggunakan acara response
untuk mendapatkan saiz fail dan acara data
terbina dalam untuk mengira dan mengeluarkan peratusan yang dimuat turun.
- Mengendalikan pengalihan semula
Serupa dengan modul HTTP, kami juga boleh menggunakan modul Permintaan untuk mengendalikan pengalihan pautan muat turun fail. Berikut ialah contoh:
const request = require('request'); const fs = require('fs'); const url = 'http://example.com/file.pdf'; const filePath = './file.pdf'; function downloadFile(url, filePath) { request(url) .on('response', (response) => { const { statusCode } = response; if (statusCode === 301 || statusCode === 302) { console.warn(`文件重定向: ${response.headers.location}`); downloadFile(response.headers.location, filePath); return; } if (statusCode !== 200) { console.error(`请求下载文件出错: 状态码 ${statusCode}`); return; } response.pipe(fs.createWriteStream(filePath)).on('finish', () => { console.log('下载完成'); }); }) .on('error', (err) => { console.error(`请求下载文件出错: ${err.message}`); }); } downloadFile(url, filePath);
Dalam kod di atas, kami menggunakan statusCode
untuk menyemak kod status respons. Jika 301 atau 302, keluarkan mesej yang diubah hala dan muat turun semula fail. Jika bukan 200, mesej ralat akan dikeluarkan.
Ringkasan
Artikel ini memperkenalkan cara menggunakan modul HTTP dan modul Permintaan untuk memuat turun fail dalam Node.js. Ia termasuk langkah asas untuk memuat turun fail menggunakan modul HTTP dan modul Permintaan, mengendalikan kemajuan muat turun dan mengendalikan pengalihan pautan muat turun fail. Node.js menyediakan fungsi muat turun fail yang sangat mudah, yang boleh melaksanakan muat turun fail dengan mudah.
Atas ialah kandungan terperinci Bagaimana untuk memuat turun fail dalam nodejs. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

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



Artikel ini membincangkan useeffect dalam React, cangkuk untuk menguruskan kesan sampingan seperti pengambilan data dan manipulasi DOM dalam komponen berfungsi. Ia menerangkan penggunaan, kesan sampingan yang biasa, dan pembersihan untuk mencegah masalah seperti kebocoran memori.

Lazy memuatkan kelewatan memuatkan kandungan sehingga diperlukan, meningkatkan prestasi web dan pengalaman pengguna dengan mengurangkan masa beban awal dan beban pelayan.

Artikel ini menerangkan algoritma perdamaian React, yang dengan cekap mengemas kini DOM dengan membandingkan pokok DOM maya. Ia membincangkan manfaat prestasi, teknik pengoptimuman, dan kesan terhadap pengalaman pengguna. Kira -kira: 159

Artikel ini membincangkan kari dalam JavaScript, teknik yang mengubah fungsi multi-argumen ke dalam urutan fungsi argumen tunggal. Ia meneroka pelaksanaan kari, faedah seperti aplikasi separa, dan kegunaan praktikal, meningkatkan kod baca

Fungsi pesanan yang lebih tinggi dalam JavaScript meningkatkan ketabahan kod, kebolehgunaan semula, modulariti, dan prestasi melalui abstraksi, corak umum, dan teknik pengoptimuman.

Artikel ini menerangkan USEContext dalam React, yang memudahkan pengurusan negara dengan mengelakkan penggerudian prop. Ia membincangkan faedah seperti keadaan terpusat dan penambahbaikan prestasi melalui pengurangan semula yang dikurangkan.

Artikel membincangkan penyambungan komponen reaksi ke kedai redux menggunakan Connect (), menerangkan MapStateToprops, MapdispatchToprops, dan kesan prestasi.

Artikel membincangkan menghalang tingkah laku lalai dalam pengendali acara menggunakan kaedah pencegahanDefault (), faedahnya seperti pengalaman pengguna yang dipertingkatkan, dan isu -isu yang berpotensi seperti kebimbangan aksesibiliti.
