Punycode
유니코드 도메인 이름을 ASCII 호환 인코딩으로 변환하여 xn-- 접두사가 붙은 ASCII 문자열로 나타냅니다. münchen.de → xn--mnchen-3ya.de.
What Is Punycode?
Punycode is an ASCII-compatible encoding algorithm for Unicode strings, defined in RFC 3492. It converts a Unicode string — potentially containing characters from any script — into a string using only ASCII letters, digits, and hyphens. Punycode is the mechanism that makes Internationalized Domain Names (IDNs) work within the ASCII-only DNS infrastructure.
A Punycode-encoded IDN label is prefixed with xn-- to mark it as an ACE (ASCII Compatible Encoding) label. The full domain münchen.de becomes xn--mnchen-3ya.de in Punycode.
The Algorithm
Punycode represents a Unicode string in two parts, separated by a hyphen:
- Basic code points (ASCII characters): copied verbatim before the final hyphen.
- Non-basic code points: encoded as delta values (variable-length integers) appended after the hyphen.
münchen → m-u-n-c-h-e-n (basic) + ü (non-basic: ü = U+00FC)
xn--mnchen-3ya
^ ^
| encoding of position and value of ü
basic chars minus ü
The algorithm uses a generalized variable-length integer (generalized variable-length quantity, or "base-36 with bias") to encode the insertion positions and code point values compactly.
Examples
# Python standard library
"münchen".encode("punycode") # b"mnchen-3ya"
"例え.jp".split(".")[0].encode("punycode") # b"r8jz45g"
# With xn-- prefix (full IDNA encoding)
"münchen.de".encode("idna") # b"xn--mnchen-3ya.de"
"例え.jp".encode("idna") # b"xn--r8jz45g.jp"
# Decoding
b"mnchen-3ya".decode("punycode") # "münchen"
b"xn--mnchen-3ya.de".decode("idna") # "münchen.de"
Common Punycode Examples
| Unicode Domain | Punycode |
|---|---|
münchen.de |
xn--mnchen-3ya.de |
例え.jp |
xn--r8jz45g.jp |
中文.com |
xn--fiq228c.com |
한국어.한국 |
xn--bj0bj06e.xn--3e0b707e |
مثال.إختبار |
xn--mgbh0fb.xn--kgbechtv |
пример.испытание |
xn--e1afmapc.xn--80akhbyknj4f |
Punycode in Browsers
Modern browsers display the Unicode form of IDN labels when the characters all come from a single script and the label passes homograph safety checks. Mixed-script domains or suspicious lookalike characters trigger display of the Punycode form as a security warning:
User types: https://münchen.de/
Browser shows: https://münchen.de/ (safe: all Latin)
DNS query: xn--mnchen-3ya.de
User types: https://pаypal.com/ (Cyrillic а)
Browser shows: https://xn--pypal-4ve.com/ (suspicious: mixed script)
Punycode for Non-DNS Uses
Although designed for DNS, Punycode can encode any Unicode string. It is sometimes used in email systems (IDNA for the domain part) and in IRI (Internationalized Resource Identifier) processing. However, other encodings like percent-encoding are preferred for URL paths and query strings.
Limitations
- Not encryption or compression: Punycode is purely a reversible encoding for ASCII transport.
- Label length: Each DNS label encoded in Punycode must not exceed 63 ASCII characters.
- Readability:
xn--fiq228c.comis meaningless to humans — the whole point of IDN display in browsers is to hide this from users.
Quick Facts
| Property | Value |
|---|---|
| RFC | RFC 3492 |
| Purpose | ASCII-compatible encoding for Unicode strings in DNS |
| Prefix for IDN labels | xn-- |
| Character set | a–z, 0–9, - |
| Encoding style | Basic ASCII copied; non-basic encoded as delta integers |
| Python codec | "punycode" (bare) or "idna" (with xn-- prefix) |
| Max encoded label | 63 ASCII characters |
관련 용어
웹 & HTML의 더 많은 용어
응답의 문자 인코딩을 선언하는 HTTP 헤더 매개변수(Content-Type: text/html; charset=utf-8). 문서 내 인코딩 …
::before 및 ::after 의사 요소를 통해 유니코드 이스케이프를 사용하여 생성된 콘텐츠를 삽입하는 …
CSS properties (direction, writing-mode, unicode-bidi) controlling text layout direction. Works with Unicode …
HTML에서 문자를 텍스트로 표현하는 방식. 세 가지 형태: 이름(&), 십진수(&), 16진수(&). HTML …
ECMAScript Internationalization API providing locale-aware string comparison (Collator), number formatting (NumberFormat), date …
CSS supports Unicode via escape sequences (\2713 for ✓), the content property …
XML 버전의 숫자 문자 참조: ✓ 또는 ✓. XML에는 명명된 엔티티가 5개(& …
비ASCII 유니코드 문자를 포함하는 도메인 이름으로, 내부적으로는 Punycode(xn--...)로 저장되지만 사용자에게는 유니코드로 표시됩니다. …
U+2060. 줄 바꿈을 방지하는 너비 없는 문자. 너비 없는 줄 바꿈 없는 …
사람이 읽기 쉬운 이름을 사용하는 HTML 엔티티: © → ©, — → …