亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用node.JS中的url模塊解析URL信息

 更新時(shí)間:2020年02月06日 13:39:04   作者:小火柴的藍(lán)色理想  
本文將詳細(xì)介紹nodeJS中的URL模塊的使用方法,利用URL模塊解析出URL相關(guān)信息

在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ī)(小寫)

'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'

protocol: 請(qǐng)求協(xié)議, 小寫

'http:'

slashes: 協(xié)議要求的斜杠(冒號(hào)后)

true 或 false

host: 完整的 URL 小寫 主機(jī)部分,包含端口信息

'host.com:8080'

auth: url 中的驗(yàn)證信息

'user:pass'

hostname: 域名中的小寫主機(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)文章

  • Node.js console控制臺(tái)簡(jiǎn)單用法分析

    Node.js console控制臺(tái)簡(jiǎn)單用法分析

    這篇文章主要介紹了Node.js console控制臺(tái)簡(jiǎn)單用法,結(jié)合實(shí)例形式分析了nodejs console控制臺(tái)功能、常見(jiàn)函數(shù)與簡(jiǎn)單使用技巧,需要的朋友可以參考下
    2019-01-01
  • Node.js如何提取文件中的中文字符

    Node.js如何提取文件中的中文字符

    這篇文章主要介紹了Node.js如何提取文件中的中文字符,本文介紹了在Node.js開(kāi)發(fā)中如何使用代碼提取文件中的中文字符,幫助開(kāi)發(fā)者更好地處理中文文本數(shù)據(jù),提高開(kāi)發(fā)效率
    2023-05-05
  • node.js mongoose index索引操作

    node.js mongoose index索引操作

    在 Mongoose 中,索引(Index)是一種用于提高查詢性能的數(shù)據(jù)結(jié)構(gòu),它可以加速對(duì)數(shù)據(jù)庫(kù)中文檔的檢索操作,本文給大家介紹
    node.js mongoose index索引操作
    ,感興趣的朋友一起看看吧
    2023-12-12
  • 使用node.js搭建服務(wù)器

    使用node.js搭建服務(wù)器

    最近需要完成一個(gè)課程設(shè)計(jì),被項(xiàng)目經(jīng)理(組長(zhǎng))分配寫界面功能,下面小編通過(guò)本文給大家分享使用使用node搭建小型服務(wù)器的方法,需要的朋友參考下
    2017-05-05
  • node 解析圖片二維碼的內(nèi)容代碼實(shí)例

    node 解析圖片二維碼的內(nèi)容代碼實(shí)例

    這篇文章主要介紹了node 解析圖片二維碼的內(nèi)容代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • 詳解nodejs微信jssdk后端接口

    詳解nodejs微信jssdk后端接口

    本篇文章主要介紹了詳解nodejs微信jssdk后端接口,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • 用Node寫一條配置環(huán)境的指令

    用Node寫一條配置環(huán)境的指令

    這篇文章主要介紹了用Node寫一條配置環(huán)境的指令,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • node省市區(qū)三級(jí)數(shù)據(jù)性能測(cè)評(píng)實(shí)例分析

    node省市區(qū)三級(jí)數(shù)據(jù)性能測(cè)評(píng)實(shí)例分析

    這篇文章主要介紹了node省市區(qū)三級(jí)數(shù)據(jù)性能,結(jié)合具體實(shí)例形式評(píng)測(cè)分析了node省市區(qū)三級(jí)數(shù)據(jù)的實(shí)現(xiàn)、改進(jìn)方法與運(yùn)行效率,需要的朋友可以參考下
    2019-11-11
  • Node.js利用debug模塊打印出調(diào)試日志的方法

    Node.js利用debug模塊打印出調(diào)試日志的方法

    debug日志打印模塊主要實(shí)現(xiàn)功能是帶命名空間(模塊名)、時(shí)間戳、色彩輸出日志;將日志寫入文件;瀏覽器端使用;格式化函數(shù);支持自定義方法。下面這篇文章主要介紹了Node.js利用debug模塊打印出調(diào)試日志的方法,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-04-04
  • 基于Node.js構(gòu)建一個(gè)靈活的CLI命令行工具

    基于Node.js構(gòu)建一個(gè)靈活的CLI命令行工具

    在軟件開(kāi)發(fā)中,命令行界面(CLI)工具是必不可少的助手,本文主要介紹了如何使用Node.js構(gòu)建一個(gè)靈活的CLI工具,涵蓋從基礎(chǔ)命令處理到復(fù)雜的交互式問(wèn)答和遠(yuǎn)程模板下載,需要的可以參考下
    2024-03-03

最新評(píng)論