如何检查 domain.com 或 sub.domain.com



我尝试了$_SERVER['HTTP_HOST']$_SERVER['SERVER_NAME'],但它们都返回 sub.domain.com,我希望它检查URL是否 sub.domain.com,或者只是 domain.com

脚本在 sub.domain.com 上运行,它们都返回相同的数据。

$_SERVER['HTTP_HOST']回报:sub.domain.com $_SERVER['SERVER_NAME']回报:sub.domain.com

我只想获得网址的 domain.com 部分。由于脚本可以在任何子域名上运行,因此我不确定如何做到这一点,因为上述两个变量都返回相同的信息。

我会检查HTTP_HOST。通常两者是相同的,但有时SERVER_NAME设置不同。如有疑问,请检查它们。

"HTTP_HOST"
主机的内容:来自当前请求的标头(如果有)。

http://php.net/manual/en/reserved.variables.server.php

至于如何检查它们,您可以为主域名做一个字符串替换,看看结果字符串是否为空。剩下的任何东西都是子域。


到目前为止,您正在寻找一些琐碎的字符串操作,这里是最后两部分:

$yourhost = implode('.', array_slice(explode('.', $_SERVER['HTTP_HOST']), -2));

您可以尝试以下功能(可在 php.net 中找到)

<?php 
function getHost($Address) { 
$parseUrl = parse_url(trim($Address)); 
return trim($parseUrl[host] ? $parseUrl[host] : array_shift(explode('/', $parseUrl[path],     2))); 
} 
getHost("example.com"); // Gives example.com 
getHost("http://example.com"); // Gives example.com 
getHost("www.example.com"); // Gives www.example.com 
getHost("http://example.com/xyz"); // Gives example.com 
?> 

肮脏的黑客

$explodedHost = explode('.', $_SERVER['HTTP_HOST']);
$size         = count($explodedHost);
$domain       = $explodedHost[$size - 2] . '.' . $explodedHost[$size - 1] . 'com';
if ($_SERVER['HTTP_HOST'] == $domain) {
  // you are on domain.com
}

相关内容

最新更新