選單
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

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

如果您在計算機上執行了相同的步驟,當開啟這兩個地址時,您應該會看到兩個不同的結果。

https://:8080/summer.html

將產生此結果

夏天

我喜歡陽光!

https://:8080/winter.html

將產生此結果

冬天

我喜歡雪!


×

聯絡銷售

如果您想將 W3Schools 服務用於教育機構、團隊或企業,請傳送電子郵件給我們
sales@w3schools.com

報告錯誤

如果您想報告錯誤,或想提出建議,請傳送電子郵件給我們
help@w3schools.com

W3Schools 經過最佳化,旨在方便學習和培訓。示例可能經過簡化,以提高閱讀和學習體驗。教程、參考資料和示例會不斷審查,以避免錯誤,但我們無法保證所有內容的完全正確性。使用 W3Schools 即表示您已閱讀並接受我們的使用條款Cookie 和隱私政策

版權所有 1999-2024 Refsnes Data。保留所有權利。W3Schools 由 W3.CSS 提供支援