用于将 URL 与或不具有 http://www 匹配的正则表达式模式
我根本不擅长正则表达式。
到目前为止,我一直在使用很多框架代码,但是我无法找到一个能够匹配URL的代码,但它也能够捕获类似和.http://www.example.com/etcetc
www.example.com/etcetc
example.com/etcetc
我根本不擅长正则表达式。
到目前为止,我一直在使用很多框架代码,但是我无法找到一个能够匹配URL的代码,但它也能够捕获类似和.http://www.example.com/etcetc
www.example.com/etcetc
example.com/etcetc
为了匹配所有类型的 URL,以下代码应该有效:
<?php
$regex = "((https?|ftp)://)?"; // SCHEME
$regex .= "([a-z0-9+!*(),;?&=$_.-]+(:[a-z0-9+!*(),;?&=$_.-]+)?@)?"; // User and Pass
$regex .= "([a-z0-9\-\.]*)\.(([a-z]{2,4})|([0-9]{1,3}\.([0-9]{1,3})\.([0-9]{1,3})))"; // Host or IP
$regex .= "(:[0-9]{2,5})?"; // Port
$regex .= "(/([a-z0-9+$_%-]\.?)+)*/?"; // Path
$regex .= "(\?[a-z+&\$_.-][a-z0-9;:@&%=+/$_.-]*)?"; // GET Query
$regex .= "(#[a-z_.-][a-z0-9+$%_.-]*)?"; // Anchor
?>
然后,检查正则表达式的正确方法如下:
<?php
if(preg_match("~^$regex$~i", 'www.example.com/etcetc', $m))
var_dump($m);
if(preg_match("~^$regex$~i", 'http://www.example.com/etcetc', $m))
var_dump($m);
?>
礼貌:splattermania在PHP手册中发表的评论:http://php.net/manual/en/function.preg-match.php
这在我测试过的所有情况下都对我有用:
$url_pattern = '/((http|https)\:\/\/)?[a-zA-Z0-9\.\/\?\:@\-_=#]+\.([a-zA-Z0-9\&\.\/\?\:@\-_=#])*/';
测试:
http://test.test-75.1474.stackoverflow.com/
https://www.stackoverflow.com
https://www.stackoverflow.com/
http://wwww.stackoverflow.com/
http://wwww.stackoverflow.com
http://test.test-75.1474.stackoverflow.com/
http://www.stackoverflow.com
http://www.stackoverflow.com/
stackoverflow.com/
stackoverflow.com
http://www.example.com/etcetc
www.example.com/etcetc
example.com/etcetc
user:pass@example.com/etcetc
example.com/etcetc?query=aasd
example.com/etcetc?query=aasd&dest=asds
http://stackoverflow.com/questions/6427530/regular-expression-pattern-to-match-url-with-or-without-http-www
http://stackoverflow.com/questions/6427530/regular-expression-pattern-to-match-url-with-or-without-http-www/
每个有效的 Internet URL 至少有一个点,因此上述模式将简单地尝试查找由点链接的至少两个字符串,并且该字符串具有 URL 可能具有的有效字符。