新聞中心
怎么在node.JS中使用url模塊解析URL信息?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)自2013年起,先為沈陽(yáng)等服務(wù)建站,沈陽(yáng)等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為沈陽(yáng)企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。
解析URL
解析 URL 對(duì)象有以下內(nèi)容,依賴于他們是否在 URL 字符串里存在。任何不在 URL 字符串里的部分,都不會(huì)出現(xiàn)在解析對(duì)象里
'http://user:[email protected]: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:[email protected]: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,類(lèi)似//foo/bar里的foo就會(huì)被認(rèn)為是hostname;如果為false,則foo被認(rèn)為是pathname的一部分
var url = require('url'); var str = 'http://user:[email protected]: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:[email protected]: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:[email protected]: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:[email protected]: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:[email protected]: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
解析時(shí)相對(duì)的基本 URL。 to
要解析的超鏈接 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'
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。
名稱欄目:怎么在node.JS中使用url模塊解析URL信息
URL網(wǎng)址:http://fisionsoft.com.cn/article/jddpjj.html