- Assertion Testing
- Buffer
- C/C++ Addons
- Child Processes
- Cluster
- Command Line Options
- Console
- Crypto
- Debugger
- DNS
- Domain
- Errors
- Events
- File System
- Globals
- HTTP
- HTTPS
- Modules
- Net
- OS
- Path
- Process
- Punycode
- Query Strings
- Readline
- REPL
- Stream
- String Decoder
- Timers
- TLS/SSL
- TTY
- UDP/Datagram
- URL
- Utilities
- V8
- VM
- ZLIB
Node.js v7.0.0-nightly20160601f81f0c351a Documentation
Table of Contents
URL#
Stability: 2 - Stable
The url module provides utilities for URL resolution and parsing. It can be
accessed using:
const url = require('url');
URL Strings and URL Objects#
A URL string is a structured string containing multiple meaningful components. When parsed, a URL object is returned containing properties for each of these components.
The following details each of the components of a parsed URL. The example
'http://user:pass@host.com:8080/p/a/t/h?query=string#hash' is used to
illustrate each.
┌─────────────────────────────────────────────────────────────────────────────┐
│                                    href                                     │
├──────────┬┬───────────┬─────────────────┬───────────────────────────┬───────┤
│ protocol ││   auth    │      host       │           path            │ hash  │
│          ││           ├──────────┬──────┼──────────┬────────────────┤       │
│          ││           │ hostname │ port │ pathname │     search     │       │
│          ││           │          │      │          ├─┬──────────────┤       │
│          ││           │          │      │          │ │    query     │       │
"  http:   // user:pass @ host.com : 8080   /p/a/t/h  ?  query=string   #hash "
│          ││           │          │      │          │ │              │       │
└──────────┴┴───────────┴──────────┴──────┴──────────┴─┴──────────────┴───────┘
(all spaces in the "" line should be ignored -- they're purely for formatting)
urlObject.href#
The href property is the full URL string that was parsed with both the
protocol and host components converted to lower-case.
For example: 'http://user:pass@host.com:8080/p/a/t/h?query=string#hash'
urlObject.protocol#
The protocol property identifies the URL's lower-cased protocol scheme.
For example: 'http:'
urlObject.slashes#
The slashes property is a boolean with a value of true if two ASCII
forward-slash characters (/) are required following the colon in the
protocol.
urlObject.host#
The host property is the full lower-cased host portion of the URL, including
the port if specified.
For example: 'host.com:8080'
urlObject.auth#
The auth property is the username and password portion of the URL, also
referred to as "userinfo". This string subset follows the protocol and
double slashes (if present) and preceeds the host component, delimited by an
ASCII "at sign" (@). The format of the string is {username}[:{password}],
with the [:{password}] portion being optional.
For example: 'user:pass'
urlObject.hostname#
The hostname property is the lower-cased host name portion of the host
component without the port included.
For example: 'host.com'
urlObject.port#
The port property is the numeric port portion of the host component.
For example: '8080'
urlObject.pathname#
The pathname property consists of the entire path section of the URL. This
is everything following the host (including the port) and before the start
of the query or hash components, delimited by either the ASCII question
mark (?) or hash (#) characters.
For example '/p/a/t/h'
No decoding of the path string is performed.
urlObject.search#
The search property consists of the entire "query string" portion of the
URL, including the leading ASCII question mark (?) character.
For example: '?query=string'
No decoding of the query string is performed.
urlObject.path#
The path property is a concatenation of the pathname and search
components.
For example: '/p/a/t/h?query=string'
No decoding of the path is performed.
urlObject.query#
The query property is either the "params" portion of the query string (
everything except the leading ASCII question mark (?), or an object
returned by the querystring module's parse() method:
For example: 'query=string' or {'query': 'string'}
If returned as a string, no decoding of the query string is performed. If returned as an object, both keys and values are decoded.
urlObject.hash#
The hash property consists of the "fragment" portion of the URL including
the leading ASCII hash (#) character.
For example: '#hash'
url.format(urlObject)#
- urlObject<Object> A URL object (either as returned by- url.parse()or constructed otherwise).
The url.format() method processes the given URL object and returns a formatted
URL string.
The formatting process essentially operates as follows:
- A new empty string resultis created.
- If urlObject.protocolis a string, it is appended as-is toresult.
- Otherwise, if urlObject.protocolis notundefinedand is not a string, anErroris thrown.
- For all string values of urlObject.protocolthat do not end with an ASCII colon (:) character, the literal string:will be appended toresult.
- If either the urlObject.slashesproperty is true,urlObject.protocolbegins with one ofhttp,https,ftp,gopher, orfile, orurlObject.protocolisundefined, the literal string//will be appended toresult.
- If the value of the urlObject.authproperty is truthy, and eitherurlObject.hostorurlObject.hostnameare notundefined, the value ofurlObject.authwill be coerced into a string and appended toresultfollowed by the literal string@.
- If the urlObject.hostproperty isundefinedthen:- If the urlObject.hostnameis a string, it is appended toresult.
- Otherwise, if urlObject.hostnameis notundefinedand is not a string, anErroris thrown.
- If the urlObject.portproperty value is truthy, andurlObject.hostnameis notundefined:- The literal string :is appended toresult, and
- The value of urlObject.portis coerced to a string and appended toresult.
 
- The literal string 
 
- If the 
- Otherwise, if the urlObject.hostproperty value is truthy, the value ofurlObject.hostis coerced to a string and appended toresult.
- If the urlObject.pathnameproperty is a string that is not an empty string:- If the urlObject.pathnamedoes not start with an ASCII forward slash (/), then the literal string '/' is appended toresult.
- The value of urlObject.pathnameis appended toresult.
 
- If the 
- Otherwise, if urlObject.pathnameis notundefinedand is not a string, anErroris thrown.
- If the urlObject.searchproperty isundefinedand if theurlObject.queryproperty is anObject, the literal string?is appended toresultfollowed by the output of calling thequerystringmodule'sstringify()method passing the value ofurlObject.query.
- Otherwise, if urlObject.searchis a string:- If the value of urlObject.searchdoes not start with the ASCII question mark (?) character, the literal string?is appended toresult.
- The value of urlObject.searchis appended toresult.
 
- If the value of 
- Otherwise, if urlObject.searchis notundefinedand is not a string, anErroris thrown.
- If the urlObject.hashproperty is a string:- If the value of urlObject.hashdoes not start with the ASCII hash (#) character, the literal string#is appended toresult.
- The value of urlObject.hashis appended toresult.
 
- If the value of 
- Otherwise, if the urlObject.hashproperty is notundefinedand is not a string, anErroris thrown.
- resultis returned.
url.parse(urlString[, parseQueryString[, slashesDenoteHost]])#
- urlString<string> The URL string to parse.
- parseQueryString<boolean> If- true, the- queryproperty will always be set to an object returned by the- querystringmodule's- parse()method. If- false, the- queryproperty on the returned URL object will be an unparsed, undecoded string. Defaults to- false.
- slashesDenoteHost<boolean> If- true, the first token after the literal string- //and preceeding the next- /will be interpreted as the- host. For instance, given- //foo/bar, the result would be- {host: 'foo', pathname: '/bar'}rather than- {pathname: '//foo/bar'}. Defaults to- false.
The url.parse() method takes a URL string, parses it, and returns a URL
object.
url.resolve(from, to)#
- from<string> The Base URL being resolved against.
- to<string> The HREF URL being resolved.
The url.resolve() method resolves a target URL relative to a base URL in a
manner similar to that of a Web browser resolving an anchor tag HREF.
For example:
url.resolve('/one/two/three', 'four')         // '/one/two/four'
url.resolve('http://example.com/', '/one')    // 'http://example.com/one'
url.resolve('http://example.com/one', '/two') // 'http://example.com/two'
Escaped Characters#
URLs are only permitted to contain a certain range of characters. Spaces (' ')
and the following characters will be automatically escaped in the
properties of URL objects:
< > " ` \r \n \t { } | \ ^ '
For example, the ASCII space character (' ') is encoded as %20. The ASCII
forward slash (/) character is encoded as %3C.