checkdnsrr
(PHP 4, PHP 5)
checkdnsrr — Проверяет записи DNS, соответствующие переданному имени узла интернета или IP-адресу
Описание
$host
[, string $type
= "MX"
] )
Ищет записи DNS типа type
,
соответствующие host
.
Список параметров
-
host
-
Параметр
host
может быть IP-адресом в виде четырех десятичных чисел, разделенных точками, или именем узла. -
type
-
Параметр
type
может быть одним из: A, MX, NS, SOA, PTR, CNAME, AAAA, A6, SRV, NAPTR, TXT or ANY.
Возвращаемые значения
Возвращает TRUE
, если были найдены записи; возвращает FALSE
, если записей
не было найдено или произошла ошибка.
Список изменений
Версия | Описание |
---|---|
5.3.0 | Функция стала доступна на платформе Windows. |
5.2.4 |
Добавлено значение TXT параметра type .
|
5.0.0 |
Добавлено значение AAAA параметра type .
|
Примечания
Замечание:
Для совместимости с более ранними версиями PHP под Windows, где не было реализации этой функции, используйте класс » PEAR » Net_DNS.
Смотрите также
- dns_get_record() - Получение DNS свойств и характеристик хоста
- getmxrr() - Получает запись MX, соответствующую переданному доменному имени узла
- gethostbyaddr() - Получает доменное имя узла, соответствующее переданному IP-адресу
- gethostbyname() - Получает адрес IPv4, соответствующий переданному имени узла интернета
- gethostbynamel() - Возвращает список адресов IPv4, соответствующих переданному доменному имени узла
- страница руководства named(8)
- checkdnsrr
- closelog
- define_syslog_variables
- dns_check_record
- dns_get_mx
- dns_get_record
- fsockopen
- gethostbyaddr
- gethostbyname
- gethostbynamel
- gethostname
- getmxrr
- getprotobyname
- getprotobynumber
- getservbyname
- getservbyport
- header_register_callback
- header_remove
- header
- headers_list
- headers_sent
- http_response_code
- inet_ntop
- inet_pton
- ip2long
- long2ip
- openlog
- pfsockopen
- setcookie
- setrawcookie
- socket_get_status
- socket_set_blocking
- socket_set_timeout
- syslog
Коментарии
criffoh at gmail dot com is right. Before you check domain, you must convert to ascii with idn_to_ascii function:
http://us2.php.net/manual/en/function.idn-to-ascii.php .
var_dump(checkdnsrr('ñandu.cl', 'A')); // returns false
var_dump(checkdnsrr(idn_to_ascii('ñandu.cl'), 'A')); // return true
Important Warning:
You need to add a dot to the end of the host name to make a fully qualified domain name.
To see why, try executing the following pieces of code:
$d1="gmail.con";
$d2="gmail.con.";
$r1=checkdnsrr($d1, "MX");
$r2=checkdnsrr($d2, "MX");
var_dump($r1);
var_dump($r2);
You will see that without the dot it claims that the domain "gmail.con" is valid.
Note that if you time the "checkdnsrr()" calls you will also see it takes longer without the dot because it treats it as a relative domain and does several tries based on the host name it is running on.
NB: in case you're interested, being treated as a relative domain explains what is happening. If your host is "example.com" the relative domain will eventually resolve to "gmail.con.com." which can be looked up, hence it wrongly claims "gmail.con" exists
I always think you should state the blindingly obvious.
A function that contains checkdnsrr will return false without an internet connection.
So in a production environment you need an active internet connection to return a true result with a valid email address.