url: fix resolving from non-file to file URLs.
When resolving a reference URL with the 'file' scheme an no host against a base URL without the 'file' scheme, the first path element of the reference URL is used as the host for the target URL. This results in an invalid target URL. This change makes an exception for file URLs so that the host is not mangled during URL resolution. PR-URL: https://github.com/iojs/io.js/pull/1277 Reviewed-By: Roman Reiss <me@silverwind.io> Reviewed-By: Ben Noordhuis <info@bnoordhuis.nl> Reviewed-By: Petka Antonov <petka_antonov@hotmail.com>
This commit is contained in:
parent
8c6c376a94
commit
1e94057c05
@ -495,7 +495,9 @@ Url.prototype.resolveObject = function(relative) {
|
||||
}
|
||||
|
||||
result.protocol = relative.protocol;
|
||||
if (!relative.host && !hostlessProtocol[relative.protocol]) {
|
||||
if (!relative.host &&
|
||||
!/^file:?$/.test(relative.protocol) &&
|
||||
!hostlessProtocol[relative.protocol]) {
|
||||
var relPath = (relative.pathname || '').split('/');
|
||||
while (relPath.length && !(relative.host = relPath.shift()));
|
||||
if (!relative.host) relative.host = '';
|
||||
|
@ -1189,7 +1189,9 @@ var relativeTests = [
|
||||
['http://example.com/b//c//d;p?q#blarg',
|
||||
'http:/a/b/c/d',
|
||||
'http://example.com/a/b/c/d'],
|
||||
['/foo/bar/baz', '/../etc/passwd', '/etc/passwd']
|
||||
['/foo/bar/baz', '/../etc/passwd', '/etc/passwd'],
|
||||
['http://localhost', 'file:///Users/foo', 'file:///Users/foo'],
|
||||
['http://localhost', 'file://foo/Users', 'file://foo/Users']
|
||||
];
|
||||
relativeTests.forEach(function(relativeTest) {
|
||||
var a = url.resolve(relativeTest[0], relativeTest[1]),
|
||||
|
Loading…
x
Reference in New Issue
Block a user