idn_to_ascii
(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL intl >= 1.0.2, PECL idn >= 0.1)
idn_to_ascii — 將域名轉換為 IDNA ASCII 格式
說明
過程化風格
idn_to_ascii(
string
int
int
array
): string|false
string
$domain
,int
$options
= IDNA_DEFAULT,int
$variant
= INTL_IDNA_VARIANT_UTS46,array
&$idna_info
= ?): string|false
該函式可以將 Unicode 域名轉換為 IDNA ASCII 相容格式。
參數
-
domain
-
要轉換的域,必須使用 UTF-8 編碼。
-
options
-
轉換選項 — IDNA_* 開頭的常量(除 IDNA_ERROR_* 開頭的常量)。
-
variant
-
對於 IDNA 2003 是
INTL_IDNA_VARIANT_2003
(自 PHP 7.2.0 起已棄用), 對於 UTS #46 是INTL_IDNA_VARIANT_UTS46
(僅 ICU 4.6 起可用)。 -
idna_info
-
僅當
INTL_IDNA_VARIANT_UTS46
用於variant
時,才可以使用該參數。 在這種情況下,它將用這些鍵組成的陣列來填充:'result'
鍵,轉換結果(有可能是一個非法結果);'isTransitionalDifferent'
鍵,布爾值,指示使用 UTS #46 的過濾機制是否會改變結果;'errors'
鍵,是 IDNA_ERROR_* 常量集里一個常量對應的 int 。
返回值
IDNA ASCII 相容格式編碼的域名, 或者在失敗時返回 false
更新日誌
版本 | 說明 |
---|---|
7.4.0 |
現在 variant 的預設值為 INTL_IDNA_VARIANT_UTS46 ,
而不是已棄用的 INTL_IDNA_VARIANT_2003 。
|
7.2.0 |
INTL_IDNA_VARIANT_2003 已被棄用;
可以使用 INTL_IDNA_VARIANT_UTS46 代替。
|
範例
示例 #1 idn_to_ascii() 示例
<?php
echo idn_to_ascii('täst.de');
?>
以上例程會輸出:
xn--tst-qla.de