我正在尝试使用正则表达式(来自Javascript)来验证域名列表。例如,如果用户输入:
facebook.com
stackoverflow.com
apple.com
......正则表达式应该验证好。然而,
facebook.com
clearlynotadomainname
apple.com
...应该验证失败。
我正在使用正则表达式:
^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}$
适用于第一行文本,但只要用户输入第一个CR / LF,表达式就会失败。是否有可能让regex迭代或以其他方式解析字符串中的所有行?
答案 0 :(得分:2)
为什么不简单地在换行符上拆分字符串?假设你想忽略空行:
function testString(str) {
var regex = /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}(\n|$)/
var split = str.split('\n')
for(var i = 0; i < split.length; ++i) {
if(split[i] != ''&& !regex.test(split[i]))
return false
}
return true
}
testString('facebook.com\nstackoverflow.com\napple.com')
=> true
testString('facebook.com\nclearlynotadomainname\napple.com')
=> false
答案 1 :(得分:0)
要验证[,;]域(仅),可以使用:
^\s*(?:(?:\w+(?:-+\w+)*\.)+[a-z]+)\s*(?:[;,]\s*(?:(?:\w+(?:-+\w+)*\.)+[a-z]+)\s*)*$
经过不同案例的测试。