2010-11-30 81 views
7

我做了:URL正则表达式验证

/^(http[s]?://){0,1}(www.){0,1}[a-zA-Z0-9\.\-]+\.[a-zA-Z]{2,5}[\.]{0,1} 

,并用验证检查,但我的网页上它不工作:

var re = /^(http[s]?://){0,1}(www.){0,1}[a-zA-Z0-9\.\-]+\.[a-zA-Z]{2,5}[\.]{0,1}; 
if (!re.test(url)) { 
    alert("url error"); 
    return false; 
} 

我得到这个错误

Webpage error details 

User Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; Media Center PC 6.0; .NET4.0C; .NET4.0E) 
Timestamp: Tue, 30 Nov 2010 14:23:10 UTC 


Message: Expected ')' in regular expression 
Line: 781 
Char: 23 
Code: 0 
URI: http://************************* 
+0

你使用了什么验证器?它是JS特定的?请记住,正则表达式因环境而异。 – 2010-11-30 14:36:20

+0

我已经使用js one ...我不知道什么是错 – 2010-11-30 14:43:30

回答

18

您必须转义您的特殊字符(/.www在此情况)和ATT失踪后/,像这样:

var re = /^(http[s]?:\/\/){0,1}(www\.){0,1}[a-zA-Z0-9\.\-]+\.[a-zA-Z]{2,5}[\.]{0,1}/; 
if (!re.test(url)) { 
    alert("url error"); 
    return false; 
} 
+0

我是怎么错过的! :-) – 2010-11-30 14:41:17

0

正如尼克说你有,除非你使用其他delimitor逃脱\.让你的正则表达式将变为:

var re = '~(https?)://)?(www\.)?[a-zA-Z0-9.-]+\.[a-zA-Z]{2,5}\.?~'; 

但要知道,你的正则表达式匹配的网址,如:

http://....aa. 
1

我会后,虽然问题已被接受。

该正则表达式仍然不完整。

http://www.-1-.de不是有效的域名,但会通过您的测试。

下面是我用什么:

~^ 
(?:ht|f)tps?:// 

(?:[a-z0-9] (?:[a-z0-9-]*[a-z0-9])?  \.)* 

(?:[a-z0-9][a-z0-9-]{0,62}[a-z0-9]) 
(?:\.[a-z]{2,5}){1,2} 

$~ix 

占地面积HTTP(S),FTP(S)和.co.uk顶级域名等。还包括可以是1个字符长度的子域(移动版本的网页为m.example.com),但不允许m-.example.com

当然,有些人可能会反对正则表达式的完整性,因为.pro TLD需要至少4个字符作为域名。 ;-)

此外,IDN域名只会在转换后通过我的正则表达式(即“xn--”格式)。

0

以防万一你想知道的网址确实存在:

function url_exist($url){//se passar a URL existe 
    $c=curl_init(); 
    curl_setopt($c,CURLOPT_URL,$url); 
    curl_setopt($c,CURLOPT_HEADER,1);//get the header 
    curl_setopt($c,CURLOPT_NOBODY,1);//and *only* get the header 
    curl_setopt($c,CURLOPT_RETURNTRANSFER,1);//get the response as a string from curl_exec(), rather than echoing it 
    curl_setopt($c,CURLOPT_FRESH_CONNECT,1);//don't use a cached version of the url 
    if(!curl_exec($c)){ 
     //echo $url.' inexists'; 
     return false; 
    }else{ 
     //echo $url.' exists'; 
     return true; 
    } 
    //$httpcode=curl_getinfo($c,CURLINFO_HTTP_CODE); 
    //return ($httpcode<400); 
} 
0

经过长期的研究后,我建立这个reg表达式。我希望它也能帮助别人.......

url = 'https://google.co.in'; 
    var re = /[a-z0-9-\.]+\.[a-z]{2,4}\/?([^\s<>\#%"\,\{\}\\|\\\^\[\]`]+)?$/; 
    if (!re.test(url)) { 
    alert("url error"); 
    return false; 
}else{ 
alert('success') 
}