S3.Blog

18 Января 2025
A A A   RSS-лента
"Я знаю, что ничего не знаю, но многие не знают и этого". Сократ [?].

Perl: Конвертация домена в зоне .рф в punycode

Дата последнего изменения: 15 Апреля 2011
Метки статьи: Готовые решения, Perl
Ну вот, добрался прогресс и до нас. Сегодня пришло тех.задание проапдейтить мой SEO-инструмент, что б можно было использовать домены в зоне .рф. Казалось бы что тут сложного, а не тут-то было, из четырех опробованных готовых библиотек, найденных на CPAN, только одна корректно отработала.
 

URI::UTF8::Punycode - Punycode conversion of UTF-8 string.
Вот моё готовое решение по её использованию:

перевод в ASCII:
use URI::UTF8::Punycode;

my $domain = 'президент.рф';
print puny_encode_domain($domain);

sub puny_encode_domain {
	my $domain = shift;

	my @puny_words = ();
	foreach my $d (split(/\./, $domain)) {
		if ($d !~ m/[a-zA-Z0-9]/i) {
			$d = URI::UTF8::Punycode::puny_enc($d);
		}
		push(@puny_words, $d);
	}
	my $result = join('.', @puny_words);
	return $result;
}


перевод в UTF8:
use URI::UTF8::Punycode;

my $domain = 'xn--d1abbgf6aiiy.xn--p1ai';
print puny_decode_domain($domain);

sub puny_decode_domain {
	my $domain = shift;

	my @puny_words = ();
	foreach my $d (split(/\./, $domain)) {
		if ($d =~ /^xn--/) {
			$d = URI::UTF8::Punycode::puny_dec($d);
		}
		push(@puny_words, $d);
	}
	my $result = join('.', @puny_words);
	return $result;
}


Где еще почитать:
Wikipedia: Punycode
Perl перекодировка в Punycode
Функции PHP для работы с IDN-доменами
PHP PEAR-модуль для работы с IDN



Похожие материалы:




програмёр (гость) • ответить

Условие
if ($d !~ m/[a-zA-Z0-9]/i) {
не точное...
Например из за него "а1" не конвертируется в xn--1-7sb
Rus (гость) • ответить
Ога, вот так правильно. цифры нельзя исключать. ну и с /i не надо печислять A-Z отдельно
if ($d !~ m/[a-z]/i)
Snelius (гость) • ответить
можно использовать core модуль URI для конвертации, причём он ничего не сделает с латинскими именами. например так print URI->new('http://домен.рф')->host.
Магомед (гость) • ответить
Добрый день.. ребята.. помощь нужна.. я пытался по этим готовым решениям свою задачу решить но не получается..
Сервер centos 6.6 с dns сервером bind. и возникла такая необходимость чтоб автоматом перекодировала домены рф.
есть файл (test) с содержанием списка доменов .рф все домены каждая в отдельности в новой строке..
мне нужен скрипт который ее прочтет переведет все строки на punycode и запишет в другой файл (test1)
заранее спасибо
Александрответить
так а в чем проблема? что именно не получается?
примеры рабочие - я сам лично их писал.
может быть у вас проблема с кодировкой?
Магомед (гость) • ответить
пытаюсь сделать по первому скрипту.. для просмотра как скрипт работает я ничего не менял. создал файл 1.pl дал права 777 и запускаю. я не такой знаток скритов. может что я не так делаю
вот вывод
./1.pl
./1.pl: line 1: sub: команда не найдена
./1.pl: line 2: my: команда не найдена
./1.pl: line 4: syntax error near unexpected token `('
./1.pl: line 4: ` my @puny_words = ();'
Александрответить
пришлите мне скрипт на емейл: pag77@mail.ru
Магомед (гость) • ответить
sub puny_encode_domain {
my $domain = shift;

my @puny_words = ();
foreach my $d (split(/\./, $domain)) {
if ($d !~ m/[a-zA-Z0-9]/i) {
$d = URI::UTF8:unycode:uny_enc($d);
}
push(@puny_words, $d);
}
my $result = join('.', @puny_words);
return $result;
}
Elias292 (гость) • ответить
Я вот так поменял:


sub puny_encode_domain {
$domain = shift;

@puny_words = ();
foreach $d (split(/\./, $domain)) {
if ($d !~ m/[a-zA-Z]/i) {
$d = URI::UTF8:unycode:uny_enc($d) unless $d =~ m/^\d+$/;
}
push(@puny_words, $d);
}
$result = join('.', @puny_words);
return $result;
}

вроде работает.

 
 
  Имя *:   Решите пример *: =
 
Полужирный Курсив Подчеркнутый Перечеркнутый
 
Вставить изображение Сделать цитатой Вставить ссылку Вставить код

Вставить смайл
 
 

 



© S3.Blog: Если критикуешь, не предлагая решения проблемы, то ты становишься частью этой проблемы.