小程序制作工具_使用node.JS中的url模块解析URL信息

2021-01-06 15:09| 发布者: | 查看: |

使用node.JS中的url模块解析URL信息       本文将详细介绍nodeJS中的URL模块的使用方法,利用URL模块解析出URL相关信息

在HTTP部分,详细介绍了URL的相关知识。而nodejs中的url模块提供了一些实用函数,用于URL处理与解析。

解析URL

解析 URL 对象有以下内容,依赖于他们是否在 URL 字符串里存在。任何不在 URL 字符串里的部分,都不会出现在解析对象里

'p/a/t/h query=string#hash'

┌─────────────────────────────────────────────────────────────────────────────┐

│ href │

├──────────┬┬───────────┬─────────────────┬───────────────────────────┬───────┤

│ protocol ││ auth │ host │ path │ hash │

│ ││ ├──────────┬──────┼──────────┬────────────────┤ │

│ ││ │ hostname │ port │ pathname │ search │ │

│ ││ │ │ │ ├─┬──────────────┤ │

│ ││ │ │ │ │ │ query │ │

" http: // user:pass @ : 8080 /p/a/t/h query=string #hash "

│ ││ │ │ │ │ │ │ │

└──────────┴┴───────────┴──────────┴──────┴──────────┴─┴──────────────┴───────┘

href: 准备解析的完整的 URL,包含协议和主机(小写)

'p/a/t/h query=string#hash'

protocol: 请求协议, 小写

'http:'

slashes: 协议要求的斜杠(冒号后)

true 或 false

host: 完整的 URL 小写 主机部分,包含端口信息

':8080'

auth: url 中的验证信息

'user:pass'

hostname: 域名中的小写主机名

''

port: 主机的端口号

'8080'

pathname: URL 中的路径部分,在主机名后,查询字符前,包含第一个斜杠

'/p/a/t/h'

search: URL 中的查询字符串,包含开头的问号

' query=string'

path: pathname 和 search 连在一起

'/p/a/t/h query=string'

query: 查询字符串中得参数部分,或者使用 querystring.parse() 解析后返回的对象

'query=string' or {'query':'string'}

hash: URL 的 “#” 后面部分(包括 # 符号)

'#hash'
URL方法

URL模块包含分析和解析 URL 的工具。调用 require('url') 来访问模块

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 字符串,返回一个对象

第二个参数parseQueryString(默认为false),如为false,则urlObject.query为未解析的字符串,比如author=%E5%B0%8F%E7%81%AB%E6%9F%B4,且对应的值不会decode;如果parseQueryString为true,则urlObject.query为object,比如{ author: '小火柴' },且值会被decode

第三个参数slashesDenoteHos(默认为false),如果为true,可以正确解析不带协议头的URL,类似//foo/bar里的foo就会被认为是hostname;如果为false,则foo被认为是pathname的一部分

var url = require('url');
var str = 'p/a/t/h author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash';
Url {
 protocol: 'http:',
 slashes: true,
 auth: 'user:pass',
 host: ':8080',
 port: '8080',
 hostname: '',
 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: '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 = 'p/a/t/h author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash'; Url { protocol: 'http:', slashes: true, auth: 'user:pass', host: ':8080', port: '8080', hostname: '', 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: 'p/a/t/h author=%E5%B0%8F%E7%81%AB%E6%9F%B4#hash' } console.log(url.parse(str,true));
url.format(urlObject)

url.parse(str)的反向操作,输入一个解析过的 URL 对象,返回格式化过的字符串

urlObject包含了很多字段,比如protocol、slashes、protocol等,且不一定需要全部传,所以有一套解析逻辑

格式化的工作流程如下

href 会被忽略

protocol 无论是否有末尾的 : (冒号),会同样的处理

http, htt凡科抠图, ftp, gopher, file 协议会被添加后缀://

mailto, xmpp, aim, sftp, foo, 等协议添加后缀:

slashes 如果协议需要 ://,设置为 true

仅需对之前列出的没有斜杠的协议,比如议 mongodb://localhost:8000/

auth 如果出现将会使用.

hostname 仅在缺少 host 时使用

port 仅在缺少 host 时使用

host 用来替换 hostname 和 port

pathname 无论结尾是否有 / 将会同样处理

search 将会替代 query属性

无论前面是否有 / 将会同样处理

query (对象; 参见 querystring) 如果没有 search,将会使用

hash 无论前面是否有#,都会同样处理


//pre> url.resolve(from, to)

url.resolve()方法以一种浏览器解析超链接的方式把一个目标URL解析成相对于一个基础URL,参数如下

from String 解析时相对的基本 URL。

to String 要解析的超链接 URL。


var url = require('url'); console.log(url.resolve('/one/two/three', 'four')); // '/one/two/four' console.log(url.resolve('', '/one')); // 'one' console.log(url.resolve('one', '/two')); // 'two'

更多关于node.JS中url模块的使用方法大家可参考下面的相关链接


<
>

 
QQ在线咨询
售前咨询热线
18720358503
售后服务热线
18720358503
返回顶部