php从URL中提取域名的2个方法

方法一

源网址:http://www.madeby83.com/php-2-kinds-of-methods-to-extract-domain-name-from-url.html

转换后:madeby83.com


function get_domain($url)  
{  
$pattern = "/[/w-]+/.(com|net|org|gov|biz|com.tw|com.hk|com.ru|net.tw|net.hk|net.ru|info|cn|com.cn|net.cn|org.cn|gov.cn|mobi|name|sh|ac|la|travel|tm|us|cc|tv|jobs|asia|hn|lc|hk|bz|com.hk|ws|tel|io|tw|ac.cn|bj.cn|sh.cn|tj.cn|cq.cn|he.cn|sx.cn|nm.cn|ln.cn|jl.cn|hl.cn|js.cn|zj.cn|ah.cn|fj.cn|jx.cn|sd.cn|ha.cn|hb.cn|hn.cn|gd.cn|gx.cn|hi.cn|sc.cn|gz.cn|yn.cn|xz.cn|sn.cn|gs.cn|qh.cn|nx.cn|xj.cn|tw.cn|hk.cn|mo.cn|org.hk|is|edu|mil|au|jp|int|kr|de|vc|ag|in|me|edu.cn|co.kr|gd|vg|co.uk|be|sg|it|ro|com.mo)(/.(cn|hk))*/";  
preg_match($pattern, $url, $matches);  
if(count($matches) > 0)  
{  
return $matches[0];  
}else{  
$rs = parse_url($url);  
$main_url = $rs["host"];  
if(!strcmp(long2ip(sprintf("%u",ip2long($main_url))),$main_url))  
{  
return $main_url;  
}else{  
$arr = explode(".",$main_url);  
$count=count($arr);  
$endArr = array("com","net","org");//com.cn net.cn 等情况  
if (in_array($arr[$count-2],$endArr))  
{  
$domain = $arr[$count-3].".".$arr[$count-2].".".$arr[$count-1];  
}else{  
$domain = $arr[$count-2].".".$arr[$count-1];  
}  
return $domain;  
}  
}  
}  

方法二

用自带函数,好处是使用方便,我现在使用的就是这个

如果你不想要www,可以用str_replace替换掉

$no_www_message=str_replace(‘www.’,”,$message);


$Url='http://www.madeby83.com/php-2-kinds-of-methods-to-extract-domain-name-from-url.html';  
$tempu=parse_url($Url);  
$message=$tempu['host'];  
echo $message;  
//输出结果就是 www.madeby83.com

Comments are closed.