New URL()-WHATWG URL API

2022-02-21 00:00:00 server node.js javascript

我正在处理节点,并尝试获取URL类的一个实例(因为这些方便的属性)。点赞:

const { URL } = require('url');
(...)
http.createServer((request,response) => {
    let uri = new URL(request.url);
    (...)
}

但失败,错误为

TypeError [ERR_INVALID_URL]: Invalid URL: /

这很有趣,因为

const url = require('url');
url.parse();

有效。所以我对它产生了好奇心。我知道后一种方法比较老。

我在本地开发,所以要发送请求,我在浏览器中使用localhost:8000。

如何使用request中的信息实例化新的URL对象?

我已经看过的信息和内容:

node -v
v9.3.0

https://nodejs.org/api/url.html#url_class_url
https://stackoverflow.com/questions/44738065/uncaught-typeerror-url-is-not-a-constructor-using-whatwg-url-object-support-for
https://stackoverflow.com/questions/45047840/in-node-js-how-to-get-construct-url-string-from-whatwg-url-including-user-and-pa
https://stackoverflow.com/questions/47481784/does-url-parse-protect-against-in-a-url
https://stackoverflow.com/questions/17184791/node-js-url-parse-and-pathname-property

解决方案

正如Joshua Wise在Github(https://github.com/nodejs/node/issues/12682)上指出的那样,问题在于request.url不是一个绝对的URL。它可以用作路径或相对URL,但缺少主机和协议。

在API documentation之后,您可以通过提供一个基本URL作为第二个参数来构造一个有效的URL。这仍然很尴尬,因为该协议不容易从request.headers获得。我只是假设HTTP:

var baseURL = 'http://' + request.headers.host + '/';
var myURL = new URL(request.url, baseURL);

这显然不是一个理想的解决方案,但至少您可以利用查询字符串解析。例如,

URL {
  href: 'http://localhost:8080/?key1=value1&key2=value2',
  origin: 'http://localhost:8080',
  protocol: 'http:',
  username: '',
  password: '',
  host: 'localhost:8080',
  hostname: 'localhost',
  port: '8080',
  pathname: '/',
  search: '?key1=value1&key2=value2',
  searchParams: URLSearchParams { 'key1' => 'value1', 'key2' => 'value2' },
  hash: '' }

相关文章