Skip to content

Punycode

Устарело с версии: v7.0.0

[Стабильность: 0 - Устарело]

Стабильность: 0 Стабильность: 0 - Устарело

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

Встроенный в Node.js модуль punycode объявлен устаревшим. В будущих основных версиях Node.js этот модуль будет удален. Пользователям, использующим модуль punycode, следует перейти на предоставленный сторонними разработчиками модуль Punycode.js. Для кодирования URL на основе Punycode см. url.domainToASCII или, в более общем плане, WHATWG URL API.

Модуль punycode является встроенной версией модуля Punycode.js. Доступ к нему можно получить следующим образом:

js
const punycode = require('node:punycode')

Punycode — это схема кодирования символов, определенная в RFC 3492, которая в основном предназначена для использования в международных доменных именах. Поскольку имена узлов в URL-адресах ограничены только символами ASCII, доменные имена, содержащие символы, отличные от ASCII, должны быть преобразованы в ASCII с помощью схемы Punycode. Например, японский символ, который переводится как английское слово 'example', — это '例'. Международное доменное имя '例.com' (эквивалентное 'example.com') представлено в Punycode как строка ASCII 'xn--fsq.com'.

Модуль punycode обеспечивает простую реализацию стандарта Punycode.

Модуль punycode является зависимостью от сторонних разработчиков, используемой Node.js и предоставляемой разработчикам для удобства. Исправления или другие изменения модуля должны быть направлены в проект Punycode.js.

punycode.decode(string)

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

Метод punycode.decode() преобразует строку Punycode, состоящую только из символов ASCII, в эквивалентную строку кодовых точек Unicode.

js
punycode.decode('maana-pta') // 'mañana'
punycode.decode('--dqo34k') // '☃-⌘'

punycode.encode(string)

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

Метод punycode.encode() преобразует строку из кодовых точек Unicode в строку Punycode Punycode, состоящую только из символов ASCII.

js
punycode.encode('mañana') // 'maana-pta'
punycode.encode('☃-⌘') // '--dqo34k'

punycode.toASCII(domain)

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

Метод punycode.toASCII() преобразует строку Unicode, представляющую собой интернационализированное доменное имя, в Punycode. Преобразуются только не-ASCII части доменного имени. Вызов punycode.toASCII() для строки, которая уже содержит только символы ASCII, не окажет никакого эффекта.

js
// кодирование доменных имён
punycode.toASCII('mañana.com') // 'xn--maana-pta.com'
punycode.toASCII('☃-⌘.com') // 'xn----dqo34k.com'
punycode.toASCII('example.com') // 'example.com'

punycode.toUnicode(domain)

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

Метод punycode.toUnicode() преобразует строку, представляющую доменное имя, содержащее закодированные в Punycode символы, в Unicode. Преобразуются только части доменного имени, закодированные в Punycode.

js
// декодирование доменных имён
punycode.toUnicode('xn--maana-pta.com') // 'mañana.com'
punycode.toUnicode('xn----dqo34k.com') // '☃-⌘.com'
punycode.toUnicode('example.com') // 'example.com'

punycode.ucs2

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

punycode.ucs2.decode(string)

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

Метод punycode.ucs2.decode() возвращает массив, содержащий числовые значения кодовых точек каждого символа Unicode в строке.

js
punycode.ucs2.decode('abc') // [0x61, 0x62, 0x63]
// пара суррогатных символов для U+1D306 тетраграмма для центра:
punycode.ucs2.decode('\uD834\uDF06') // [0x1D306]

punycode.ucs2.encode(codePoints)

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

Метод punycode.ucs2.encode() возвращает строку на основе массива числовых значений кодовых точек.

js
punycode.ucs2.encode([0x61, 0x62, 0x63]) // 'abc'
punycode.ucs2.encode([0x1d306]) // '\uD834\uDF06'

punycode.version

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

Возвращает строку, идентифицирующую текущий номер версии Punycode.js.