使用node.JS中的url模塊解析URL信息
在HTTP部分,詳細(xì)介紹了URL的相關(guān)知識(shí)。而nodejs中的url模塊提供了一些實(shí)用函數(shù),用于URL處理與解析。
解析URL
解析 URL 對(duì)象有以下內(nèi)容,依賴于他們是否在 URL 字符串里存在。任何不在 URL 字符串里的部分,都不會(huì)出現(xiàn)在解析對(duì)象里
'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'
┌─────────────────────────────────────────────────────────────────────────────┐
│ href │
├──────────┬┬───────────┬─────────────────┬───────────────────────────┬───────┤
│ protocol ││ auth │ host │ path │ hash │
│ ││ ├──────────┬──────┼──────────┬────────────────┤ │
│ ││ │ hostname │ port │ pathname │ search │ │
│ ││ │ │ │ ├─┬──────────────┤ │
│ ││ │ │ │ │ │ query │ │
" http: // user:pass @ host.com : 8080 /p/a/t/h ? query=string #hash "
│ ││ │ │ │ │ │ │ │
└──────────┴┴───────────┴──────────┴──────┴──────────┴─┴──────────────┴───────┘
href: 準(zhǔn)備解析的完整的 URL,包含協(xié)議和主機(jī)(小寫(xiě))
'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'
protocol: 請(qǐng)求協(xié)議, 小寫(xiě)
'http:'
slashes: 協(xié)議要求的斜杠(冒號(hào)后)
true 或 false
host: 完整的 URL 小寫(xiě) 主機(jī)部分,包含端口信息
'host.com:8080'
auth: url 中的驗(yàn)證信息
'user:pass'
hostname: 域名中的小寫(xiě)主機(jī)名
'host.com'
port: 主機(jī)的端口號(hào)
'8080'
pathname: URL 中的路徑部分,在主機(jī)名后,查詢字符前,包含第一個(gè)斜杠
'/p/a/t/h'
search: URL 中的查詢字符串,包含開(kāi)頭的問(wèn)號(hào)
'?query=string'
path: pathname 和 search 連在一起
'/p/a/t/h?query=string'
query: 查詢字符串中得參數(shù)部分,或者使用 querystring.parse() 解析后返回的對(duì)象
'query=string' or {'query':'string'}
hash: URL 的 “#” 后面部分(包括 # 符號(hào))
'#hash'
URL方法
URL模塊包含分析和解析 URL 的工具。調(diào)用 require('url') 來(lái)訪問(wèn)模塊
var url = require('url');
/*
{ parse: [Function: urlParse],
resolve: [Function: urlResolve],
resolveObject: [Function: urlResolveObject],
format: [Function: urlFormat],
Url: [Function: Url] }
*/
console.log(url);
url.parse(urlStr[, parseQueryString][, slashesDenoteHost])
輸入 URL 字符串,返回一個(gè)對(duì)象
第二個(gè)參數(shù)parseQueryString(默認(rèn)為false),如為false,則urlObject.query為未解析的字符串,比如author=%E5%B0%8F%E7%81%AB%E6%9F%B4,且對(duì)應(yīng)的值不會(huì)decode;如果parseQueryString為true,則urlObject.query為object,比如{ author: '小火柴' },且值會(huì)被decode
第三個(gè)參數(shù)slashesDenoteHos(默認(rèn)為false),如果為true,可以正確解析不帶協(xié)議頭的URL,類似//foo/bar里的foo就會(huì)被認(rèn)為是hostname;如果為false,則foo被認(rèn)為是pathname的一部分
var url = require('url');
var str = 'http://user:pass@host.com:8080/p/a/t/h?author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash';
/*
Url {
protocol: 'http:',
slashes: true,
auth: 'user:pass',
host: 'host.com:8080',
port: '8080',
hostname: 'host.com',
hash: '#hash',
search: '?author=%E5%B0%8F%E7%81%AB%E6%9F%B4',
query: 'author=%E5%B0%8F%E7%81%AB%E6%9F%B4',
pathname: '/p/a/t/h',
path: '/p/a/t/h?author=%E5%B0%8F%E7%81%AB%E6%9F%B4',
href: 'http://user:pass@host.com:8080/p/a/t/h?author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash' }
*/
console.log(url.parse(str));
var url = require('url');
var str = 'http://user:pass@host.com:8080/p/a/t/h?author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash';
/*
Url {
protocol: 'http:',
slashes: true,
auth: 'user:pass',
host: 'host.com:8080',
port: '8080',
hostname: 'host.com',
hash: '#hash',
search: '?author=%E5%B0%8F%E7%81%AB%E6%9F%B4',
query: { author: '小火柴' },
pathname: '/p/a/t/h',
path: '/p/a/t/h?author=%E5%B0%8F%E7%81%AB%E6%9F%B4',
href: 'http://user:pass@host.com:8080/p/a/t/h?author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash' }
*/
console.log(url.parse(str,true));
var url = require('url');
var str = '//foo/bar';
var result1 = url.parse(str,true);
var result2 = url.parse(str,true,true);
console.log(result1.path);//'//foo/bar'
console.log(result1.pathname);//'//foo/bar'
console.log(result1.hostname);//null
console.log(result2.path);//'/bar'
console.log(result2.pathname);//'/bar'
console.log(result2.hostname);//'foo'
url.format(urlObject)
url.parse(str)的反向操作,輸入一個(gè)解析過(guò)的 URL 對(duì)象,返回格式化過(guò)的字符串
urlObject包含了很多字段,比如protocol、slashes、protocol等,且不一定需要全部傳,所以有一套解析邏輯
格式化的工作流程如下
href 會(huì)被忽略
protocol 無(wú)論是否有末尾的 : (冒號(hào)),會(huì)同樣的處理
http, https, ftp, gopher, file 協(xié)議會(huì)被添加后綴://
mailto, xmpp, aim, sftp, foo, 等協(xié)議添加后綴:
slashes 如果協(xié)議需要 ://,設(shè)置為 true
僅需對(duì)之前列出的沒(méi)有斜杠的協(xié)議,比如議 mongodb://localhost:8000/
auth 如果出現(xiàn)將會(huì)使用.
hostname 僅在缺少 host 時(shí)使用
port 僅在缺少 host 時(shí)使用
host 用來(lái)替換 hostname 和 port
pathname 無(wú)論結(jié)尾是否有 / 將會(huì)同樣處理
search 將會(huì)替代 query屬性
無(wú)論前面是否有 / 將會(huì)同樣處理
query (對(duì)象; 參見(jiàn) querystring) 如果沒(méi)有 search,將會(huì)使用
hash 無(wú)論前面是否有#,都會(huì)同樣處理
var url = require('url');
var obj = {
protocol: 'http:',
auth: 'user:pass',
host: 'host.com:8080',
hash: '#hash',
query: { author: '小火柴' }
}
//http://user:pass@host.com:8080?author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash
console.log(url.format(obj));
url.resolve(from, to)
url.resolve()方法以一種瀏覽器解析超鏈接的方式把一個(gè)目標(biāo)URL解析成相對(duì)于一個(gè)基礎(chǔ)URL,參數(shù)如下
from <String> 解析時(shí)相對(duì)的基本 URL。
to <String> 要解析的超鏈接 URL。
var url = require('url');
console.log(url.resolve('/one/two/three', 'four')); // '/one/two/four'
console.log(url.resolve('http://example.com/', '/one')); // 'http://example.com/one'
console.log(url.resolve('http://example.com/one', '/two')); // 'http://example.com/two'
更多關(guān)于node.JS中url模塊的使用方法大家可參考下面的相關(guān)鏈接
相關(guān)文章
Ajax獲取node服務(wù)器數(shù)據(jù)的完整步驟
這篇文章主要給大家介紹了關(guān)于Ajax獲取node服務(wù)器數(shù)據(jù)的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09
Node.js 8 中的 util.promisify的詳解
本篇文章主要介紹了Node.js 8 中的 util.promisify的詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
node puppeteer(headless chrome)實(shí)現(xiàn)網(wǎng)站登錄
這篇文章主要介紹了node puppeteer(headless chrome)實(shí)現(xiàn)網(wǎng)站登錄,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-05-05
基于Node.js和Socket.IO實(shí)現(xiàn)實(shí)時(shí)通信功能
在現(xiàn)代網(wǎng)絡(luò)應(yīng)用中,實(shí)時(shí)通信變得越來(lái)越重要,Node.js,作為一個(gè)JavaScript運(yùn)行環(huán)境,而Socket.IO則為Node.js提供了一個(gè)強(qiáng)大的實(shí)時(shí)通信庫(kù),本文將通過(guò)一個(gè)簡(jiǎn)單的示例,展示如何使用Node.js和Socket.IO創(chuàng)建一個(gè)能夠?qū)崿F(xiàn)實(shí)時(shí)通信的服務(wù)器,需要的朋友可以參考下2024-11-11
小結(jié)Node.js中非阻塞IO和事件循環(huán)
本文針對(duì)在Node.js關(guān)鍵的兩個(gè)概念:非阻塞IO和事件循環(huán)進(jìn)行了適當(dāng)?shù)目偨Y(jié),需要的朋友可以參考下2014-09-09
使用Raygun對(duì)Node.js應(yīng)用進(jìn)行錯(cuò)誤處理的方法
這篇文章主要介紹了使用Raygun對(duì)Node.js應(yīng)用進(jìn)行錯(cuò)誤處理的方法,Node.js是一款用于服務(wù)器端的JavaScript框架,需要的朋友可以參考下2015-06-06

