php正規截取url中網域後的內容
phpcn_u1582
phpcn_u1582 2017-05-16 13:14:30
0
5
1040

php程式
需要正規符合http://或https://開頭,保留域名,截取域名後的內容
例如http://www.baidu.com/aa/bbb只要http ://www.baidu.com把/aa/bbb截取掉

phpcn_u1582
phpcn_u1582

全部回覆(5)
某草草

不用正則也闊以啊,這個不更優雅嘛

$url = 'http://www.baidu.com/aa/bbb';
var_dump(parse_url($url));
//array(3) {
     ["scheme"]=> string(4) "http" 
     ["host"]=> string(13) "www.baidu.com" 
     ["path"]=> string(7) "/aa/bbb"
    }
迷茫
if(strncmp('http://', $url, 7) === 0 || strncmp('https://', $url, 8)) {
  $host = substr($url, strpos($url, '/', strncmp('http://', $url, 7) ? 8 : 7));
} else {
  $host = null;
}

能不用正規盡量不要用正規

巴扎黑

這個方法很多,既然要求是正規,請看下面程式碼

    $str= 'http://www.baidu.com/aa/bbb';
    $patten = '/(http[s]?:\/\/\w*.\w*.\w*\/).*/';
    preg_match($patten, $str, $match);

    echo $match[1];
仅有的幸福

https://www.bytelang.com/o/s/...

參考下面運行的答案

我想大声告诉你

explode取得不是更好嗎
為何還要用正規

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板