abouchard55 / phpwhois
phpWhois - 查询 whois 服务并解析结果的库。
Requires
- php: >=7.2
- algo26-matthias/idna-convert: ^3.0
Requires (Dev)
- dms/phpunit-arraysubset-asserts: ~0.1
- phpunit/phpunit: ^8.0 || ^9.0
Suggests
- lib-openssl: *
This package is not auto-updated.
Last update: 2024-09-26 00:14:40 UTC
README
简介
本包包含一个 PHP 的 Whois (RFC954) 库。允许 PHP 程序使用 lookup
函数创建 Whois 对象,并获取 whois 查询的输出。
响应是一个数组,至少包含一个名为 'rawdata' 的元素,包含 whois 请求的原始输出。
此外,如果域名属于存在特殊处理程序的注册商,则特殊处理程序将解析输出并在响应中提供额外的元素。这些额外元素的键在 HANDLERS.md 文件中描述。
它完全支持根据 RFC3490、RFC3491、RFC3492 和 RFC3454 定义的 IDNA(国际化)域名。
它还支持 ip/AS whois 查询,这对于追踪垃圾邮件非常有用。您只需传递点分十进制 IP 地址或 AS(自治系统)处理程序,而不是域名。还提供了有限的、非递归的 Referral Whois(RFC 1714/2167)支持。
要求
phpWhois 需要 PHP 7.0 或更高版本,并具有 OpenSSL 支持,才能正常工作。
如果没有 SSL 支持,您将无法查询没有 whois 服务器但具有基于 https 的 whois 的域名。
安装
通过 composer
稳定版本
php composer.phar require "jsmitty12/phpwhois":"^5.0"
最新开发版本
php composer.phar require "jsmitty12/phpwhois":"dev-master"
示例用法
(见 example.php
)
// Load composer framework if (file_exists(__DIR__ . '/vendor/autoload.php')) { require(__DIR__ . '/vendor/autoload.php'); } use phpWhois\Whois; $whois = new Whois(); $query = 'example.com'; $result = $whois->lookup($query,false); echo "<pre>"; print_r($result); echo "</pre>";
如果您以 UTF8 格式提供要查询的域名,则必须使用
$result = $whois->lookup($query);
如果查询字符串不是 UTF8,则必须使用 ISO-8859-1,否则 IDNA 支持将无法工作。
您可以查询的内容
您可以使用 phpWhois 查询域名、IP 地址和其他信息,例如 AS,以下两个示例都有效
use phpWhois\Whois; $whois = new Whois(); $result = $whois->lookup('example.com'); $whois = new Whois(); $result = $whois->lookup('62.97.102.115'); $whois = new Whois(); $result = $whois->lookup('AS220');
使用特殊的 whois 服务器
某些注册商可以提供对已注册 whois 网关的特殊访问权限,以便更精细地控制滥用 whois 服务。目前已知提供特殊访问的 whois 服务有
ripe
新的 ripe whois 服务器软件支持一些特殊参数,允许传递真实客户端 IP 地址。此功能仅适用于已注册网关。如果您已注册,则可以在查询 ripe IP 地址时使用此服务
use phpWhois\Whois; $whois = new Whois(); $whois->useServer('uk','whois.ripe.net?-V{version},{ip} {query}'); $result = $whois->lookup('62.97.102.115');
whois.isoc.org.il
该服务器也使用新的 ripe whois 服务器软件,因此以相同的方式工作。如果您已注册,则可以在查询 .il
域名时使用此服务
use phpWhois\Whois; $whois = new Whois(); $whois->useServer('uk','whois.isoc.org.il?-V{version},{ip} {query}'); $result = $whois->lookup('example.co.uk');
whois.nic.uk
他们为注册用户提供所谓的 WHOIS2(请参阅 http://www.nominet.org.uk/go/whois2 ),每小时允许的查询量更高。如果您已注册,则可以在查询 .uk 域名时使用此服务
use phpWhois\Whois; $whois = new Whois(); $whois->useServer('uk','whois.nic.uk:1043?{hname} {ip} {query}'); $result = $whois->lookup('example.co.uk');
此新功能还允许您通过调用 whois->useServer 并传递用于命名 tld 的服务器和参数来使用不同的 whois 服务器。例如,您可以使用此方法为 .au
域名使用另一个不受请求次数限制的 whois 服务器(但提供不了所有者信息)
use phpWhois\Whois; $whois = new Whois(); $whois->useServer('au','whois-check.ausregistry.net.au');
或
use phpWhois\Whois; $whois = new Whois(); $whois->useServer('be','whois.tucows.com');
以避免 .be
whois 服务器施加的限制
或
use phpWhois\Whois; $whois = new Whois(); $whois->useServer('ip','whois.apnic.net');
在特定的whois服务器中查找IP地址(但会失去由适当处理程序解析结果的能力)
useServer
可以调用多次。请注意,如果该域名有处理程序,它也将被调用,但由于whois服务器返回的数据可能与处理程序预期的数据不同,因此结果可能不同。
更快地获取结果
如果您只想知道一个域名是否已注册,但不关心获取真正的所有者信息,您可以设置
$whois->deepWhois = false;
这将告诉phpWhois只查询一个whois服务器。对于.com
、.net
和.tv
域名和IP地址,这将防止phpWhois询问超过一个whois服务器,您将只知道域名是否已注册以及注册商是谁,但不是所有者信息。
UTF-8
PHPWhois假定所有whois服务器都返回UTF-8编码的输出,如果某些whois服务器不返回UTF-8数据,您可以将它包含在whois.servers.php
中的NON_UTF8
数组中
获取域名信息的流程
- 调用方法
phpWhois\Whois::lookup()
,域名作为参数 - 如果方法的第二个参数是true(默认),phpWhois将尝试将域名转换为punycode
- 如果域名不在预定义的处理程序中(在
src/whois.servers.php
中的WHOIS_SPECIAL
),尝试查询[tld].whois-servers.net
。如果它有IP地址,则假设它是有效的whois服务器 - 尝试查询找到的whois服务器或使用
unknown()
方法填充响应数组
注意
有一个扩展类phpWhois\Utils
,其中包含一个名为showObject()
的调试函数,如果您执行showObject($result)
,它将输出返回对象的完整布局到网页浏览器。
该软件包的最新版本和示例脚本位于https://github.com/jsmitty12/phpwhois
贡献
如果您想添加对新TLD的支持、扩展功能或修复错误,请在Github的仓库中创建一个新的pull request:https://github.com/jsmitty12/phpwhois
致谢
Mark Jeftovic markjr@easydns.com
David Saez Padros david@ols.es
Ross Golder ross@golder.org
Dmitry Lukashin dmitry@lukashin.ru