2013-04-16 16 views
22

że ktoś wchodzi do URL tak:Uzyskaj nazwę domeny z pełnego adresu URL

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

I chcę wrócić: imgur.com

nie i.imgur.com

Jest to kod mam teraz

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

Ale to zwraca i.imgur.com

+0

opieka podzielić ?? – ramo

+0

jak o tym, który zaczyna "Oto metoda, aby uzyskać prawdziwą nazwę domeny." –

+0

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

Odpowiedz

61

Sprawdź poniższy kod, powinien to zrobić dobrze.

<?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

Działa to świetnie! Dziękuję Ci! Zaznaczę to jako najlepszą odpowiedź. – ramo

+3

To jest * mały * podchwytliwy. Kończy się to zwracaniem nieprawidłowych wyników dla subdomen ccTLD pierwszego poziomu, takich jak 'blah.blah.de'. Ale nie da się tego obejść bez użycia publicznej listy sufiksów. – duskwuff

+0

To nie zadziała dla 'www.domena.com' - parse_url() potrzebuje protokołu (http: //) do zdefiniowania hosta, w przeciwnym razie jest to po prostu ścieżka. Wymaga warunku podrzędnego w pierwszej kolejności: '$ domain = (pusty ($ 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

Ummm ... co to jest? –

+0

jest to funkcja służąca do uzyskania nazwy hosta z adresu URL.Oryginalny adres URL to Twój adres URL i $ store_url Zwróć adres URL hosta. –

-6

użyj:

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

Przykład:

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

Komenda uzyskać domenę katalogu i nie.

+0

Pytanie dotyczy adresu URL wprowadzonego przez użytkownika, a nie adresu, który odwiedza. – robmcvey

-5

Jeśli chcesz tylko nazwę domeny, wykonaj następujące czynności:

$domain = $_SERVER['SERVER_NAME']; 

echo $domain; 
5

Trzeba pakiet, który korzystając Public Suffix List. Tak, możesz użyć funkcji łańcuchowych arround parse_url() lub regex, ale wygenerują niepoprawny wynik w złożonych adresach URL.

Polecam TLDExtract do analizowania domeny, oto przykładowy kod:

$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

Znalazłem bardzo użyteczną bibliotekę przy użyciu publicsuffix.org, PHP Domain Parser jest Lista przyrostek publiczny oparty parser domeny wdrożone w 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')); 
?> 

string (16) "scottwills.co.uk"

Powiązane problemy