Skip to content

Строка запроса

[Стабильно: 2 - Стабильно]

Стабильно: 2 Стабильность: 2 - Стабильно

Исходный код: lib/querystring.js

Модуль node:querystring предоставляет утилиты для разбора и форматирования строк запроса URL. Он может быть доступен с помощью:

js
const querystring = require('node:querystring');

querystring работает быстрее, чем <URLSearchParams>, но не является стандартизованным API. Используйте <URLSearchParams>, когда производительность не критична или когда желательна совместимость с кодом браузера.

querystring.decode()

Добавлено в: v0.1.99

Функция querystring.decode() является псевдонимом для querystring.parse().

querystring.encode()

Добавлено в: v0.1.99

Функция querystring.encode() является псевдонимом для querystring.stringify().

querystring.escape(str)

Добавлено в: v0.1.25

Метод querystring.escape() выполняет URL percent-encoding для данной str таким образом, который оптимизирован для конкретных требований строк запроса URL.

Метод querystring.escape() используется querystring.stringify() и обычно не предполагается для непосредственного использования. Он экспортируется в основном для того, чтобы код приложения мог предоставить альтернативную реализацию percent-encoding, если это необходимо, путем присвоения querystring.escape альтернативной функции.

querystring.parse(str[, sep[, eq[, options]]])

[История]

ВерсияИзменения
v8.0.0Множественные пустые записи теперь анализируются правильно (например, &=&=).
v6.0.0Возвращаемый объект больше не наследуется от Object.prototype.
v6.0.0, v4.2.4Параметр eq теперь может иметь длину более 1.
v0.1.25Добавлено в: v0.1.25
  • str <string> Строка запроса URL для разбора
  • sep <string> Подстрока, используемая для разделения пар ключ-значение в строке запроса. По умолчанию: '&'.
  • eq <string>. Подстрока, используемая для разделения ключей и значений в строке запроса. По умолчанию: '='.
  • options <Object>
    • decodeURIComponent <Function> Функция, используемая при декодировании percent-encoded символов в строке запроса. По умолчанию: querystring.unescape().
    • maxKeys <number> Указывает максимальное количество ключей для разбора. Укажите 0, чтобы удалить ограничения подсчета ключей. По умолчанию: 1000.

Метод querystring.parse() анализирует строку запроса URL (str) в коллекцию пар ключ-значение.

Например, строка запроса 'foo=bar&abc=xyz&abc=123' анализируется в:

json
{
  "foo": "bar",
  "abc": ["xyz", "123"]
}

Объект, возвращаемый методом querystring.parse(), не прототипически наследуется от JavaScript Object. Это означает, что типичные методы Object, такие как obj.toString(), obj.hasOwnProperty() и другие, не определены и не будут работать.

По умолчанию предполагается, что percent-encoded символы в строке запроса используют кодировку UTF-8. Если используется альтернативная кодировка символов, необходимо указать альтернативный параметр decodeURIComponent:

js
// Предполагая, что функция gbkDecodeURIComponent уже существует...

querystring.parse('w=%D6%D0%CE%C4&foo=bar', null, null,
                  { decodeURIComponent: gbkDecodeURIComponent });

querystring.stringify(obj[, sep[, eq[, options]]])

Добавлено в: v0.1.25

  • obj <Object> Объект для сериализации в строку запроса URL
  • sep <string> Подстрока, используемая для разделения пар "ключ-значение" в строке запроса. По умолчанию: '&'.
  • eq <string>. Подстрока, используемая для разделения ключей и значений в строке запроса. По умолчанию: '='.
  • options
    • encodeURIComponent <Function> Функция, используемая для преобразования небезопасных для URL символов в процентное кодирование в строке запроса. По умолчанию: querystring.escape().

Метод querystring.stringify() создает строку запроса URL из заданного obj, перебирая "собственные свойства" объекта.

Он сериализует следующие типы значений, переданных в obj: <string> | <number> | <bigint> | <boolean> | <string[]> | <number[]> | <bigint[]> | <boolean[]> Числовые значения должны быть конечными. Любые другие входные значения будут принудительно преобразованы в пустые строки.

js
querystring.stringify({ foo: 'bar', baz: ['qux', 'quux'], corge: '' });
// Возвращает 'foo=bar&baz=qux&baz=quux&corge='

querystring.stringify({ foo: 'bar', baz: 'qux' }, ';', ':');
// Возвращает 'foo:bar;baz:qux'

По умолчанию символы, требующие процентного кодирования в строке запроса, будут закодированы как UTF-8. Если требуется альтернативная кодировка, необходимо указать альтернативный параметр encodeURIComponent:

js
// Предполагая, что функция gbkEncodeURIComponent уже существует,

querystring.stringify({ w: '中文', foo: 'bar' }, null, null,
                      { encodeURIComponent: gbkEncodeURIComponent });

querystring.unescape(str)

Добавлено в: v0.1.25

Метод querystring.unescape() выполняет декодирование символов URL, закодированных с использованием процентного кодирования, в заданной строке str.

Метод querystring.unescape() используется querystring.parse() и обычно не предназначен для непосредственного использования. Он экспортируется в основном для того, чтобы код приложения мог предоставить альтернативную реализацию декодирования, если это необходимо, путем присвоения querystring.unescape альтернативной функции.

По умолчанию метод querystring.unescape() попытается использовать встроенный в JavaScript метод decodeURIComponent() для декодирования. Если это не удастся, будет использован более безопасный эквивалент, который не выдает ошибку при неправильных URL-адресах.