2013-04-16 133 views
22

说有人进入以下网址:获取域名

http://i.imgur.com/a/b/c?query=value&query2=value 

而且我想返回:imgur.com

i.imgur.com

这是代码,我现在所拥有的

$sourceUrl = parse_url($url); 
$sourceUrl = $sourceUrl['host']; 

但这返回i.imgur.com

+0

保健佳品?? – ramo

+0

如何启动“这是获取域的真实名称的方法。” – 2013-04-16 01:13:28

+0

见:http://stackoverflow.com/questions/288810/get-the-subdomain-from-a-url – duskwuff

回答

61

检查下面的代码,它应该做的工作的罚款。

<?php 

function get_domain($url) 
{ 
    $pieces = parse_url($url); 
    $domain = isset($pieces['host']) ? $pieces['host'] : $pieces['path']; 
    if (preg_match('/(?P<domain>[a-z0-9][a-z0-9\-]{1,63}\.[a-z\.]{2,6})$/i', $domain, $regs)) { 
    return $regs['domain']; 
    } 
    return false; 
} 

print get_domain("http://mail.somedomain.co.uk"); // outputs 'somedomain.co.uk' 

?> 
+0

这很好用!谢谢!我会将此标记为最佳答案。 – ramo

+3

这是一个*小*棘手。它最终会返回第一级ccTLD的子域名的错误结果,例如'blah.blah.de'。但是,如果不使用公共后缀列表,则没有办法。 – duskwuff

+0

这不适用于'www.domain.com' - parse_url()需要一个协议(http://)来定义一个主机,否则它只是路径。需要第一个条件:'$ domain =(empty($ domain)&& isset($ pieces ['path']))? $ pieces ['path']:$ domain;' –

-1
 if(substr_count($original_url, 'http://')) { 
    if(substr_count($original_url, 'www.')) { 
     // url style would be 'http://www.abc.xxx/page?param' or http://www.abc.xxx.xx/page?param 
     // extract 'abc' 
     $temp = explode('.', $original_url); 

     $store_url = $temp[1]; 
     // now 
     // $temp[2] = xxx or xxx/page?param 
     // $temp[3] = null or xx/page?param 

     //if ($temp[3] == null) { // then we are sure that $temp[2]== "xxx/page?param" 
        if(sizeof($temp) > 3) { 
      // extract "xxx" from "xxx/page?param" and append to store url so it will be "abc.xxx" 
      $temp = explode('/',$temp[2]); 
      $store_url .= '.'.$temp[0]; 
     } 
     else { 
      // then we are sure that $temp[2]== "xxx" and then $temp[3] == "xx/page?param" 
      //     or $temp[2]== xxx/page?stripped-link from second dot(.) 
      if(substr_count($temp[2], '/')) { // in case $temp[2]== xxx/page?stripped-link from second dot(.) 
       // extract "xxx" from "xxx/page?stripped-link" and appent to store url so it will be "abc.xxx" 
       $temp = explode('/',$temp[2]); 
       $store_url .= '.'.$temp[0]; // "abc".="xxx" ==> abc.xxx 
      } 
      else { // in case $temp[2]== "xxx" and then $temp[3] == "xx/page?param" 
       $store_url .= '.'.$temp[2]; // "abc".="xxx" ==> abc.xxx 
       // extract "xx" from "xx/page?param" and appent to store url so it will be "abc.xxx.xx" 
       $temp = explode('/',$temp[3]); 
       if(strlen($temp[0])==2) { 
        $store_url .= '.'.$temp[0]; 
       } 
      } 
     } 
    } 
    else { 
     // url style would be 'http://abc.xxx/page?param' or 'http://abc.xxx.xx/page?param' 
     // remove 'http://' 
     $temp = substr($original_url, 7); 
     // now temp would be either 'abc.xxx/page?param' or 'abc.xxx.xx/page?param' 
     // explode with '/' 
     $temp = explode('/', $temp); 
     $store_url = $temp[0]; 
    } 
} 
else if(substr_count($original_url, 'www.')) { 
    // url style would be 'www.abc.xxx/page?param' or 'www.abc.xxx.xx/page?param' 
    // remove 'www.' 
    $temp = substr($original_url, 4); 
    // now, $temp would be either "abc.xxx/page?param" or "abc.xxx.xx/page?param" 
    // explode with '/' 
    $temp = explode('/', $temp); 
    $store_url = $temp[0]; 
} 
else { 
    // url style would be 'abc.xxx/page?param' or 'abc.xxx.xx/page?param' 
    //explode with '/' 
    $temp = explode('/', $original_url); 
    $store_url = $temp[0]; 
} 
+0

嗯......那是什么? –

+0

它是从url获取主机名的功能。原始网址是您的网址和$ store_url返回主机网址.. –

-6

使用本:

$uri = "$_SERVER[REQUEST_URI]";<br> 
print($uri); 

例子:

http://exemple.com/?directory<br> 
Result: 
/?diretory 

的命令,在目录中,而不是域名。

+0

该问题涉及用户输入的网址,而不是他们访问的地址。 – robmcvey

-5

如果你只想要的域名,请尝试以下操作:

$domain = $_SERVER['SERVER_NAME']; 

echo $domain; 
5

需要,使用Public Suffix List包。是的,你可以使用字符串函数arround parse_url()或regex,但是它们会在复杂的URL中产生不正确的结果。

我的域名解析建议更换TLDExtract,这里是示例代码:

$url = 'http://i.imgur.com/a/b/c?query=value&query2=value'; 

parse_url($url, PHP_URL_HOST); // will return 'i.imgur.com' 

$extract = new LayerShifter\TLDExtract\Extract(); 
$result = $extract->parse($url); 
$result->getFullHost(); // will return 'i.imgur.com' 
$result->getSubdomain(); // will return 'i' 
$result->getRegistrableDomain(); // will return 'imgur.com' 
$result->getSuffix(); // will return 'com' 
1

我一直在使用publicsuffix.org找到了一个非常有用的库, PHP Domain Parser是PHP实现基于公共后缀列表域解析器。

https://github.com/jeremykendall/php-domain-parser

<?php 
// this will do the job 

require_once '../vendor/autoload.php'; 

$pslManager = new Pdp\PublicSuffixListManager(); 
$parser = new Pdp\Parser($pslManager->getList()); 
var_dump($parser->getRegistrableDomain('www.scottwills.co.uk')); 
?> 

串(16) “scottwills.co.uk”