溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Node.js中path模塊,url模塊,http模塊怎么用

發(fā)布時間:2022-03-28 09:46:02 來源:億速云 閱讀:155 作者:小新 欄目:開發(fā)技術

小編給大家分享一下Node.js中path模塊,url模塊,http模塊怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

path模塊

Node.js中,提供了一個path模塊,在這個模塊中,提供了許多實用的,可被用來處理與轉換文件路徑的方法及屬性。path是一個系統(tǒng)模塊,不需要單獨安裝,主要用于格式化或拼接完整路徑。

1. path模塊示例

以path模塊中最常用的是join方法【拼接路徑】為例,如下所示:

 var path = require('path');
 //拼接路徑:將多個字符串拼接成一個完整的路徑
 var file = path.join(__dirname,'file1.txt');
 console.log("當前路徑:"+file);

示例截圖,如下所示:

Node.js中path模塊,url模塊,http模塊怎么用

注意:__dirname是內置屬性,表示當前程序所在的路徑。

2. path模塊其他方法

path模塊除了join外,還提供了其他方法,如下所示:

var path = require('path');
//拼接路徑:將多個字符串拼接成一個完整的路徑
var file = path.join(__dirname,'file1.txt');
console.log("當前路徑:"+file);
//返回路徑中的文件夾部分
var dirname = path.dirname(file);
//返回路徑中的文件部分,包含文件名和擴展名
var filename = path.basename(file);
//返回路徑中的擴展名
var extname = path.extname(file);
//解析路徑對象,返回一個對象
var p = path.parse(file);
console.log("dirname:"+dirname);
console.log("filename:"+filename);
console.log("extname:"+extname);
console.log("parse解析后的對象:");
console.log(p)

示例截圖,如下所示:

Node.js中path模塊,url模塊,http模塊怎么用

url模塊

URL模塊主要提供對URL(Uniform Resource Locator,統(tǒng)一資源定位器)的相關操作的屬性和方法。

網(wǎng)址字符串是包含多個有意義組件的結構化字符串。 解析時,將返回包含每個組件的屬性的網(wǎng)址對象。

url 模塊提供了兩種用于處理網(wǎng)址的 API:一種是 Node.js 特定的舊版 API,一種是實現(xiàn)了與 Web 瀏覽器使用的相同的 WHATWG 網(wǎng)址標準的新版 API。

下面提供了 WHATWG 和 舊版 API 之間的比較。

Node.js中path模塊,url模塊,http模塊怎么用

使用 WHATWG API 解析網(wǎng)址字符串:

 const myURL =
   new URL('https://user:pass@sub.example.com:8080/p/a/t/h?query=string#hash');

使用舊版 API 解析網(wǎng)址字符串:

 import url from 'url';
 const myURL =  url.parse('https://user:pass@sub.example.com:8080/p/a/t/h?query=string#hash');

1. 舊的解析方法

舊的解析方法,直接采用模塊的parse函數(shù)即可,如下所示:

 var url = require('url');
 var u="https://www.cnblogs.com/hsiang/p/15182972.html";
 //舊的解析方法
 var obj = url.parse(u);
 console.log("解析后的對象:");
 console.log(obj);

解析示例截圖,如下所示:

Node.js中path模塊,url模塊,http模塊怎么用

注意:返回的obj是一個對象,通過obj.屬性名,可以獲取更加詳細的內容。

2. 新的解析方法

 //新的解析方法【ES6寫法】
 const {URL} = require('url');
 var u="https://www.cnblogs.com/hsiang/p/15182972.html";
 const obj=new URL(u);
 console.log("新的解析方法");
 console.log(obj);

示例截圖,如下所示:

Node.js中path模塊,url模塊,http模塊怎么用

ES5寫法,如下所示:

 //新的解析方法【ES5寫法】
 var url = require('url');
 var u="https://www.cnblogs.com/hsiang/p/15182972.html";
 var obj =new  url.URL(u);
 console.log("新的解析方法");
 console.log(obj);

注意:通過對比,發(fā)現(xiàn)新舊兩種方式解析出來的結果大體上相同,僅存細微差異,具體可參考上述新舊對比截圖。

http模塊

網(wǎng)絡作為信息傳輸,接收,共享的虛擬平臺,通過它將各個點,面,體的信息聯(lián)系到一起,從而實現(xiàn)這些資源的共享。網(wǎng)絡傳輸數(shù)據(jù)有一定的規(guī)則,這些規(guī)則稱之為協(xié)議,http協(xié)議就是規(guī)則的一種,而且是使用最頻繁的一種網(wǎng)絡傳輸協(xié)議。

1. 什么是HTTP協(xié)議?

超文本傳輸協(xié)議(Hyper Text Transfer Protocol,HTTP)是一個簡單的請求-響應協(xié)議,它通常運行在TCP之上。它指定了客戶端可能發(fā)送給服務器什么樣的消息以及得到什么樣的響應。請求和響應消息的頭以ASCII形式給出;而消息內容則具有一個類似MIME的格式。HTTP協(xié)議定義了數(shù)據(jù)在瀏覽器和服務器之間網(wǎng)絡傳輸?shù)臄?shù)據(jù)格式和過程。

2. HTTP協(xié)議約束的細節(jié)

HTTTP協(xié)議定義了瀏覽器和服務器之間交互數(shù)據(jù)的格式及過程。具體如下所示:

  • 定義了瀏覽器以什么格式向服務器發(fā)送請求;

  • 定義了服務器以什么格式解析瀏覽器發(fā)送過來的數(shù)據(jù);

  • 定義了服務器以什么格式響應數(shù)據(jù)給瀏覽器;

  • 定義了瀏覽器已什么格式解析服務器響應的數(shù)據(jù);

3. HTTP請求響應過程

以瀏覽一次網(wǎng)頁為例,請求響應過程如下所示:

Node.js中path模塊,url模塊,http模塊怎么用

4. http模塊get方法

因為網(wǎng)絡中的請求,大部分都是get方式,且不帶請求體,所以Node.js的http模塊提供了便捷方法。如下所示:

var http=require('http');
var fs = require('fs');

http.get('http://www.itsource.cn',function(res){
    //res是一個IncomingMessage對象
    //console.log(res);
    var stream = fs.createWriteStream('./a.html');
    //res是流對象,可以監(jiān)聽data事件

    res.on('data',function(data){
        console.log(data.toString());
        stream.write(data);
    });
    res.on('end',function(){
        stream.end();
        console.log('下載成功');
    });
    //或者采用管道
    //res.pipe(stream);
});

上述示例采用get方法獲取文件內容,并保存文件內容到文件中。示例結果如下:

Node.js中path模塊,url模塊,http模塊怎么用

以上是“Node.js中path模塊,url模塊,http模塊怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI