Node.js URL 模組
內建 URL 模組
URL 模組將網址分解為可讀的部分。
要包含 URL 模組,請使用 require()
方法
var url = require('url');
使用 url.parse()
方法解析地址,它將返回一個 URL 物件,其中每個地址部分都作為屬性
示例
將網址分解為可讀的部分
var url = require('url');
var adr = 'https://:8080/default.htm?year=2017&month=february';
var q = url.parse(adr, true);
console.log(q.host); //返回 'localhost:8080'
console.log(q.pathname); //返回 '/default.htm'
console.log(q.search); //返回 '?year=2017&month=february'
var qdata = q.query; //返回一個物件: { year: 2017, month: 'february' }
console.log(qdata.month); //返回 'february'
執行示例 »
Node.js 檔案伺服器
現在我們知道如何解析查詢字串,並且在上一章我們學習瞭如何使 Node.js 充當檔案伺服器。讓我們將兩者結合起來,提供客戶端請求的檔案。
建立兩個 html 檔案並將它們儲存在與 node.js 檔案相同的資料夾中。
summer.html
<!DOCTYPE html>
<html>
<body>
<h1>夏天</h1>
<p>我喜歡陽光!</p>
</body>
</html>
winter.html
<!DOCTYPE html>
<html>
<body>
<h1>冬天</h1>
<p>我喜歡雪!</p>
</body>
</html>
建立一個 Node.js 檔案,該檔案開啟請求的檔案並將其內容返回給客戶端。如果發生任何錯誤,則丟擲 404 錯誤。
demo_fileserver.js
var http = require('http');
var url = require('url');
var fs = require('fs');
http.createServer(function (req, res) {
var q = url.parse(req.url, true);
var filename = "." + q.pathname;
fs.readFile(filename, function(err, data) {
if (err) {
res.writeHead(404, {'Content-Type': 'text/html'});
return res.end("404 Not Found");
}
res.writeHead(200, {'Content-Type': 'text/html'});
res.write(data);
return res.end();
});
}).listen(8080);
請記住初始化檔案
啟動 demo_fileserver.js
C:\Users\Your Name>node demo_fileserver.js
如果您在計算機上執行了相同的步驟,當開啟這兩個地址時,您應該會看到兩個不同的結果。
將產生此結果
夏天
我喜歡陽光!
將產生此結果
冬天
我喜歡雪!