URL格式

来源:互联网 发布:大一云计算 编辑:程序博客网 时间:2024/06/05 18:26

参考了百度百科,说一下URL同志的格式问题:

URL的定义:

在WWW上,每一信息资源都有统一的且在网上唯一的地址,该地址就叫URL(Uniform Resource Locator,统一资源定位符),它是WWW的统一资源定位标志,就是指网络地址。

URL的组成部分

URL由三部分组成:资源类型,存放资源的主机域名,资源文件名。

URL的一般语法格式:

(带方括号[]的为可选项):

protocol :// hostname[:port] / path / [;parameters][?query]#fragment

下面对格式进行一下说明:

protocol(协议):

指定使用的传输协议,下面也列出了几种protocol属性的有效方案名称。那我们最常用的就是HTTP协议,它也是目前www中应用最广泛的协议。
file 资源是本地计算机上的文件。格式file:///,注意后边应是三个斜杠。
ftp 通过 FTP访问资源。格式 FTP://
gopher 通过 Gopher 协议访问该资源。
http 通过 HTTP 访问该资源。 格式 HTTP://
https 通过安全的 HTTPS 访问该资源。 格式 HTTPS://
mailto 资源为电子邮件地址,通过 SMTP 访问。 格式 mailto:

hostname(主机名)

是指存放资源的服务器的域名系统(DNS) 主机名或 IP 地址。有时,在主机名前也可以包含连接到服务器所需的用户名和密码(格式:username:password@hostname)。

port(端口号)

整数,可选,省略时使用方案的默认端口,各种传输协议都有默认的端口号,如http的默认端口为80。如果输入时省略,则使用默认端口号。有时候出于安全或其他考虑,可以在服务器上对端口进行重定义,即采用非标准端口号,此时,URL中就不能省略端口号这一项。

path(路径)

由零或多个“/”符号隔开的字符串,一般用来表示主机上的一个目录或文件地址。
parameters(参数)
这是用于指定特殊参数的可选项。

parameters(参数)

这是用于指定特殊参数的可选项。

query(查询)

可选,用于给动态网页(如使用CGI、ISAPI、PHP/JSP/ASP/ASP。NET等技术制作的网页)传递参数,可有多个参数,用“&”符号隔开,每个参数的名和值用“=”符号隔开。

fragment(信息片断)

字符串,用于指定网络资源中的片断。例如一个网页中有多个名词解释,可使用fragment直接定位到某一名词解释。

URL模块

URL用于解析字符串和处理字符串,提供了三个方法

1.parse

举例:

//变量url即具有了url模块所提供的方法var url = require('url');var queryUrl = "http://localhost:8888/bb?name=bigbear&memo-helloworld";console.log(typeof url.parse(queryUrl));console.log(url.parse(queryUrl));

输出结果:

objectUrl {  protocol: 'http:',  slashes: true,  auth: null,  host: 'localhost:8888',  port: '8888',  hostname: 'localhost',  hash: null,  search: '?name=bigbear&memo-helloworld',  query: 'name=bigbear&memo-helloworld',  pathname: '/bb',  path: '/bb?name=bigbear&memo-helloworld',  href: 'http://localhost:8888/bb?name=bigbear&memo-helloworld' }

对输出结果说明一下:
protocol: 请求协议

host: URL主机名已全部转换成小写, 包括端口信息

auth:URL中身份验证信息部分

hostname:主机的主机名部分, 已转换成小写

port: 主机的端口号部分

pathname: URL的路径部分,位于主机名之后请求查询之前

search: URL 的“查询字符串”部分,包括开头的问号。

path: pathname 和 search 连在一起。

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

hash: URL 的 “#” 后面部分(包括 # 符号)
parse方法有两个参数:url字符串与一个可选的布尔值。布尔值用来确定queryString是否要用queryString模块来解析,默认为false;如果第二个参数是true,那么输出结果如下:

Url {  protocol: 'http:',  slashes: true,  auth: null,  host: 'localhost:8888',  port: '8888',  hostname: 'localhost',  hash: null,  search: '?name=bigbear&memo-helloworld',  //queryString经过queryString模块解析  query: { name: 'bigbear', 'memo-helloworld': '' },  pathname: '/bb',  path: '/bb?name=bigbear&memo-helloworld',  href: 'http://localhost:8888/bb?name=bigbear&memo-helloworld' }

format方法

format方法与parse方法相反,它是根据某个对象生成URL字符串

var url = require('url');var queryUrl = "http://localhost:8888/bb?name=bigbear&memo-helloworld#about";var object = url.parse(queryUrl);console.log(url.format(object));//输出结果http://localhost:8888/bb?name=bigbear&memo-helloworld#about

resolve方法

resolve(from,to)方法用于拼接URL,它根据相对URL拼接成新的URL

url.resolve('/one/two/three', 'four')         // '/one/two/four'url.resolve('http://huahua.com/', '/one')    // 'http://example.com/one'url.resolve('http://huahua.com/one', '/two') // 'http://example.com/two'
原创粉丝点击