如何使用PHP从更长的链接中提取链接?

时间:2013-03-21 08:28:35

标签: php regex

我想知道是否有人知道从另一个链接中提取链接的最佳方法是什么,以下是一个例子:

如果我有以下格式的链接:

http://www.youtube.com/watch?v=35HBFeB4jYg   OR
http://it.answers.yahoo.com/question/index?qid=20080520042405AApM2Rv  OR
https://www.google.it/search?q=rap+tedesco&aq=f&oq=rap+tedesco&aqs=chrome.0.57j62l2.2287&sourceid=chrome&ie=UTF-8#hl=en&sclient=psy-ab&q=migliori+programatori&oq=migliori+programatori&gs_l=serp.3..0i19j0i13i30i19l3.9986.13880.0.14127.14.10.0.4.4.0.165.931.6j4.10.0...0.0...1c.1.7.psy-ab.tPmiWRyUVXA&pbx=1&bav=on.2,or.r_cp.r_qf.&fp=ffc0e9337f73a744&biw=1280&bih=699

我如何才能仅提取网页:

http://www.youtube.com
http://it.answers.yahoo.com
https://www.google.it

我想知道是否以及我可以使用哪些正则表达式来实现这一点,这也是正则表达式的方法吗?

3 个答案:

答案 0 :(得分:2)

有一个用于解析URL的PHP​​函数:parse_url

$url = 'http://it.answers.yahoo.com/question/index?qid=20080520042405AApM2Rv';
$p = parse_url($url);
echo $p["scheme"] . "// . "$p["host"];

答案 1 :(得分:1)

使用函数parse_url

$link = "https://www.google.it/search?q=rap+tedesco";
$parseUrl = parse_url($link);
$siteName = $parseUrl['scheme']."://". $parseUrl['host'];

使用正则表达式

preg_match('@http(s?)://([\w]+\.){1}([\w]+\.?)+@',$link,$matches);
echo $matches[0];

Codeviper Demo.

答案 2 :(得分:0)

你只想拥有页面的域名,在PHP中存在一个名为parse_url的函数可以提供帮助