2

我需要知道如何在没有 tld 的情况下从 url 获取域名。

这就是我所拥有的适用于 .com、 .info 等但不适用于 .co.uk 的东西

// get host name from URL
preg_match('@^(?:http://)?([^/]+)@i',
"http://example.co.uk", $matches);
$host = $matches[1];

// get last two segments of host name
preg_match('/([^.]+)\.[^.]+$/', $host, $matches);
echo "domain name is: {$matches[1]}\n";

当我让它调用“example.co.uk”域时,它只显示:“co”,当我需要它显示“example”时

谢谢

4

1 回答 1

1

Regex 在那里是错误的解决方案,您需要使用Public Suffix List的包,只有使用它才能在复杂的 TLDS 上获得正确的结果。

我推荐TLDExtract进行域解析,这里是显示差异的示例代码:

$extract = new LayerShifter\TLDExtract\Extract();

# For 'http://www.domain.com/site'

$result = $extract->parse('http://www.domain.com/site');
$result->getFullHost(); // will return 'www.domain.com'
$result->getRegistrableDomain(); // will return 'domain.com'
$result->getSuffix(); // will return 'com'

# For 'http://www.domain.co.uk/site'

$result = $extract->parse('http://www.domain.co.uk/site');
$result->getFullHost(); // will return 'www.domain.co.uk'
$result->getRegistrableDomain(); // will return 'domain.co.uk'
$result->getSuffix(); // will return 'co.uk'
于 2016-10-02T14:55:49.213 回答