idn_to_ascii

(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL intl >= 1.0.2, PECL idn >= 0.1)

idn_to_asciiConverte nome de domínio para a forma ASCII IDNA

Descrição

Estilo procedural

idn_to_ascii(
    string $domain,
    int $flags = IDNA_DEFAULT,
    int $variant = INTL_IDNA_VARIANT_UTS46,
    array &$idna_info = null
): string|false

Esta função converte um nome de domínio Unicode para um formato compatível com ASCII IDNA.

Parâmetros

domain

O domínio a converter, que precisa ser codificado em UTF-8.

flags

Opções de conversão - combinação de constantes IDNA_* (exceto cosntantes IDNA_ERROR_*).

variant

Pode ser INTL_IDNA_VARIANT_2003 (defasado a partir do PHP 7.2.0) para IDNA 2003 ou INTL_IDNA_VARIANT_UTS46 (disponível apenas a partir da ICU 4.6) para UTS #46.

idna_info

Este parâmetro pode ser usado somente se INTL_IDNA_VARIANT_UTS46 foi usado no parâmetro variant. Neste caso, será preenchido com um array com as chaves 'result', o possível resultado ilegal da transformação, 'isTransitionalDifferent', um booleano indicando se o uso de mecanismos transicionais da UTS #46 mudou ou teria mudado o resultado e 'errors', que é um int representando um conjunto de bits das contantes de erro IDNA_ERROR_*.

Valor Retornado

O nome de domínio codificado em forma compatível com ASCII-compatible, ou false em caso de falha

Registro de Alterações

Versão Descrição
7.4.0 O valor padrão de variant agora é INTL_IDNA_VARIANT_UTS46 ao invés do defasado INTL_IDNA_VARIANT_2003.
7.2.0 INTL_IDNA_VARIANT_2003 se tornou defasado; use INTL_IDNA_VARIANT_UTS46 em seu lugar.

Exemplos

Example #1 Exemplo de idn_to_ascii()

<?php

echo idn_to_ascii('täst.de');

?>

O exemplo acima produzirá:

xn--tst-qla.de

Veja Também

  • idn_to_utf8() - Converte nome de domínio de ASCII IDNA para Unicode