用Node提供靜態文件服務
這篇文章主要介紹了關於用Node提供靜態檔案服務,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
前言
#對於一個web應用,提供靜態檔案(CSS、JavaScript、圖片)服務常常是必須的。本文將介紹如何做一個自己的靜態檔案伺服器。
建立一個靜態檔案伺服器
每個靜態檔案伺服器都有一個根目錄
,也就是提供檔案服務的基礎目錄。所以我們要在即將建立的伺服器上定義一個root變量,它將作為我們這個靜態檔案伺服器的根目錄:
var http = require('http') var join = require('path').join var fs = require('fs') var root = __dirname
__dirname 在Node中是一個神奇的變量,它的值是該檔案所在目錄的路徑。在本例中,伺服器會將這個腳本所在的目錄當作靜態檔案的根目錄。
有了檔案的路徑,還需要傳輸檔案的內容。
這可以用fs.ReadStream
完成,它是Node中Stream類別之一。成功呼叫 fs.createReadStream() 會傳回一個新的 fs.ReadStream 物件。
下面的程式碼實作了一個簡單但功能完整的檔案伺服器。
var server = http.createServer(function(req, res){ let path = join(root, req.url) let stream = fs.createReadStream(path) stream.on('data', function(chunk){ res.write(chunk) }) stream.on('end', function(){ res.end() }) }) server.listen(3000)
這個檔案伺服器大體能用,但還有很多細節要考慮。接下來我們要優化資料的傳輸,同時也精簡一下伺服器的程式碼。
用STREAM.PIPE()優化資料傳輸
雖然上面的程式碼看起來還不錯,但Node也提供了更進階的實作機制:Stream.pipe()
。用這個方法可以極大簡化伺服器的程式碼。優化後程式碼如下:
var server = http.createServer(function(req, res){ let path = join(root, req.url) let stream = fs.createReadStream(path) stream.pipe(res) }) server.listen(3000)
這種寫法,是不是更簡單,更清晰了呢?
理解流和管道
流是Node中很重要的一個概念,你可以把Node中的管道想像成水管,如果你想讓某個源頭(例如熱水器)流出來的水流到一個目的地(例如廚房的水龍頭),可以在中間加一個管道把它們連起來,這樣水就會順著管道從源頭流到目的地。
Node中的管道也是這樣,但其中流動的不是水,而是來自源頭(即ReadableStream
)的數據,管道可以讓它們「流動」到某個目的地(即WritableStream
)。你可以用pipe方法把管道連起來:
ReadableStream.pipe(WritableStream)
讀取一個檔案(ReadableStream)並把其中的內容寫到另一個檔案中(WritableStream)用的就是管道:
let readStream = fs.createReadStream('./original.txt') let writeStream = fs.createWriteStream('./copy.txt') readStream.pipe(writeStream)
所有ReadableStream都能接入任何一個WritableStream。例如HTTP請求(req)對
象就是ReadableStream,你可以讓其中的內容流動到檔案中:
req.pipe(fs.createWriteStream('./req-body.txt'))
運行
現在我們來執行上面的程式碼,我們在根目錄下放一張圖片,例如peiqi.jpg。
在瀏覽器中輸入http://127.0.0.1:3000/peiqi.jpg
,發現可愛的peiqi已經出現在你的面前了。 peiqi.jpg
被當作回應主體從http伺服器送到了客戶端(瀏覽器)。
雖然已經品嚐到了成功的滋味,但這個靜態檔案伺服器還不夠完整,因為它很容易出錯。想像一下,如果使用者不小心輸入了一個不存在的資源,例如abc.html,伺服器就會馬上崩掉。所以我們也得給這個檔案伺服器加上錯誤處理機制,讓它夠健壯
#。
處理伺服器錯誤
在Node中,所有繼承了EventEmitter的類別都可能會發出error事件。為了監聽錯誤,在fs.ReadStream上註冊一個error事件處理器(例如下面這段程式碼),回傳回應狀態碼500表示有伺服器內部錯誤:
stream.on('error', function(err){ res.statusCode = 500 res.end('服务器内部错误') })
用fs.stat()實作錯誤處理
我們可以用fs.stat()
來取得檔案的相關信息,如果檔案不存在,fs.stat()會在err.code中放入ENOENT
作為回應,然後你可以回傳錯誤碼404,向客戶端表明檔案未找到。如果fs.stat()回傳了其他錯誤碼,你可以回傳通用的錯誤碼500。
重構後的程式碼如下:
var server = http.createServer(function(req, res){ let path = join(root, req.url) fs.stat(path, function(err, stat) { if (err) { if ('ENOENT' == err.code) { res.statusCode = 404 res.end('Not Found') } else { res.statusCode = 500 res.end('服务器内部错误') } } else { // 有该文件 res.setHeader('Content-Length', stat.size) var stream = fs.createReadStream(path) stream.pipe(res) stream.on('error', function(err) { // 如果读取文件出错 res.statusCode = 500 res.end('服务器内部错误') }) } }) }) server.listen(3000)
注意
本節建構的檔案伺服器是個簡化版。如果你想把它放到生產環境中,應該更全面地檢查輸入的有效性,以防用戶透過目錄遍歷攻擊訪問你本來不想開放給他們的那部分內容。
小結
讀到這裡,相信聰明的你已經掌握瞭如何用Node創建一個靜態伺服器,下一篇文章我會給大家介紹如何用Node處理用戶上傳的文件並存放到伺服器中。
以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!
相關推薦:
##以上是用Node提供靜態文件服務的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統引言:隨著科技的不斷發展,語音辨識技術已成為了人工智慧領域的重要組成部分。而基於WebSocket和JavaScript實現的線上語音辨識系統,具備了低延遲、即時性和跨平台的特點,成為了廣泛應用的解決方案。本文將介紹如何使用WebSocket和JavaScript來實現線上語音辨識系

WebSocket與JavaScript:實現即時監控系統的關鍵技術引言:隨著互聯網技術的快速發展,即時監控系統在各個領域中得到了廣泛的應用。而實現即時監控的關鍵技術之一就是WebSocket與JavaScript的結合使用。本文將介紹WebSocket與JavaScript在即時監控系統中的應用,並給出程式碼範例,詳細解釋其實作原理。一、WebSocket技

如何利用JavaScript和WebSocket實現即時線上點餐系統介紹:隨著網路的普及和技術的進步,越來越多的餐廳開始提供線上點餐服務。為了實現即時線上點餐系統,我們可以利用JavaScript和WebSocket技術。 WebSocket是一種基於TCP協定的全雙工通訊協議,可實現客戶端與伺服器的即時雙向通訊。在即時線上點餐系統中,當使用者選擇菜餚並下訂單

如何使用WebSocket和JavaScript實現線上預約系統在當今數位化的時代,越來越多的業務和服務都需要提供線上預約功能。而實現一個高效、即時的線上預約系統是至關重要的。本文將介紹如何使用WebSocket和JavaScript來實作一個線上預約系統,並提供具體的程式碼範例。一、什麼是WebSocketWebSocket是一種在單一TCP連線上進行全雙工

JavaScript和WebSocket:打造高效的即時天氣預報系統引言:如今,天氣預報的準確性對於日常生活以及決策制定具有重要意義。隨著技術的發展,我們可以透過即時獲取天氣數據來提供更準確可靠的天氣預報。在本文中,我們將學習如何使用JavaScript和WebSocket技術,來建立一個高效的即時天氣預報系統。本文將透過具體的程式碼範例來展示實現的過程。 We

JavaScript教學:如何取得HTTP狀態碼,需要具體程式碼範例前言:在Web開發中,經常會涉及到與伺服器進行資料互動的場景。在與伺服器進行通訊時,我們經常需要取得傳回的HTTP狀態碼來判斷操作是否成功,並根據不同的狀態碼來進行對應的處理。本篇文章將教你如何使用JavaScript來取得HTTP狀態碼,並提供一些實用的程式碼範例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用於在DOM樹中插入一個新的節點。這個方法需要兩個參數:要插入的新節點和參考節點(即新節點將要插入的位置的節點)。

JavaScript中的HTTP狀態碼取得方法簡介:在進行前端開發中,我們常常需要處理與後端介面的交互,而HTTP狀態碼就是其中非常重要的一部分。了解並取得HTTP狀態碼有助於我們更好地處理介面傳回的資料。本文將介紹使用JavaScript取得HTTP狀態碼的方法,並提供具體程式碼範例。一、什麼是HTTP狀態碼HTTP狀態碼是指當瀏覽器向伺服器發起請求時,服務
