我们在web开发中,经常会用到正则来验证用户所输入和提交的内容,所以站长也会经常收集和整理一些好用的正则表达式,记录和整理本来就是学习过程中的一部分,今天在网上看到有人在询问一个正则,就自己写了一下,拿出来与大家分享。
一:要求用正则来验证用户输入的密码,至少包含大小字字母,数字和特殊符号中两种,简单的说,就是验证用户输入的密码不能太简单。
乍一想,这种正则好像不太方便下手写,至少以前站长在验证用户输入的密码格式时,都是分步来写的,比如:
if(/[a-z]/g.test(v)){
alert("不能纯为小写字母");
return false;
}else if(/[A-Z]/g.test(v)){
alert("不能纯为大写字母");
return false;
}else if(/[0-9]/g.test(v)){
alert("不能纯为数字");
return false;
}else if(/[^0-9a-zA-Z]/g.test(v)){
alert("不能纯为非字母和数字的特殊符号");
return false;
}
现在技术比以前好了那么“一丢丢”,就在想,能不能用一句正则来实现呢?当然是可以的,下面是具体的正则:
var v=$("#text").val();
reg=/^(?![0-9]+$)(?![a-z]+$)(?![A-Z]+$)(?!([^(0-9a-zA-Z)])+$).{6,}$/;
alert(reg.test(v));
上面的正则表达的意思是,不能为纯数字,不能为纯小写字母,不能为纯大写字母,不能为纯特殊符号,至少六位。
不要看着有点复杂,其实很简单的,站长来给大家拆开分析一下:
(?!) 这是正则里的一个“语法结构”,表示“规定后面不是”的意思,看这篇《jquery正则中问号的三种[说四种那是忽悠人]用法详解及在线实例演示》
了解了上面这一句,那么上面的正则就好理解了:
(?![0-9]+$) 表示后面不能为纯数字
(?![a-z]+$) 表示后面不能为纯小写字母
(?![A-Z]+$) 表示后面不能为纯大写字母
(?!([^(0-9a-zA-Z)])+$) 表示后面不能为除数字和字母外的纯特殊符号
^ 这个符号单独用表示“开头”,用在中括号的开头,表示“非”;
.{6,} 表示至少6位的任意字符
$ 表示“结尾”
二:另外还有一种情况,那就是,有时我们需要我们的密码必须为“字母+数字+特殊符号”,那么我们要如何写呢?
(?![0-9a-z]+$) 不能为小写字母与数字
(?![0-9A-Z]+$) 不能为大写字母与数字
(?![0-9\W]+$) 不能为数字及特殊符号
(?![a-z\W]+$) 不能为小写字母及特殊符号
(?![A-Z\W]+$) 不能为大写字母及特殊符号
(?![0-9a-zA-Z]+$) 不能为大写,小写字母与数字
把这三种情况也加上去后,就只剩下“必须包含数字、大小写字母和特殊符号”这一种情况了,但是我们也得出了一个超长的正则,这里就不写了!
那么有没有简单的方法呢?当然是有的:
var v=$("#text").val();
reg=/^(?=.*[a-zA-Z])(?=.*[1-9])(?=.*[\W]).{6,}$/;
alert(reg.test(v));
(?=)这个语法结构在正则里表示“设定后面是”的意思。
(?=.*[a-zA-Z]) 这句的意思就是后面必须有一位大写或小写字母
(?=.*[1-9]) 这句的意思是后面必须有一位数字
(?=.*[\W]) 这句的意思是后面必须有一个非字母数字及下划线的特殊符号
上述正则校验在实际使用中会遇到很多全角符号导致验证失败的问题,所以最后我们在项目中改成了限定特殊符号的范围。因为我们想着密码的特殊符号是为了防破解,所以一些常用的特殊符号就足够我们使用了,我们最后限定的特殊符号范围是 !@#$%^&* 这些。于是正则表达些的写法如下
var v=$("#text").val();
reg=/^(?=.*[a-zA-Z])(?=.*[1-9])(?=.*[!|@|#|$|%|^|&|*]).{6,}$/;
alert(reg.test(v));
上述结构中最后的 (?=.*[!|@|#|$|%|^|&|*]) 表示必须有一个!@#$%^&*中的一个,竖线在正则中表示多个中选一个。这样限定了范围,可以避免了很多其他全角、html预定字符等转义导致的一些列问题。