事情之余在codewars上看了一个问题,问题以下
写一个正则,考证暗码,保证以下几点,
0.位数大于六
1.必需包括小写字母
2.必需包括大写字母
3.必需包括数字
好吧,我搞了半天没搞出来,列位看官,你们晓得怎样解吗?
答案我参考了google,运用一条正则表达式是如许的
function validate(password) {
return /^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])[a-zA-Z0-9]{6,}$/.test(password);
}
这里包括了几个基本知识点,我申明一下
正则的主体是这个
/^[a-zA-Z0-9]{6,}$/
^
,$
代表从头最先到末端,量词指导从头至尾六次以上,婚配的内容是大小写加数字
主体以外,用了三个前向断言
我们先来看一下前向断言的运用
‘Windows (?=95|98|NT|2000)’ 婚配“Windows 2000”中的“Windows”,但不婚配“Windows
3.1”中的“Windows”
主体,婚配的依然是主体windows,前向断言的作用相当于一个挑选前提
所以,我们这里婚配的照样主体里那六个以上的字符,只是加了三个前提
三个什么前提?
(?=.*\d)(?=.*[a-z])(?=.*[A-Z])
.*
恣意字符涌现0或屡次背面跟\d数字,意义是只要要数字,甭管他前面有或没有恣意字符,有几个恣意字符,我们都要。
同理背面的小写,大写。
而且这三个断言相当于“并”的关联。
我们再组合来看是否是更邃晓一些了?^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])[a-zA-Z0-9]{6,}$
这句的意义是我们要从最先到完毕6个以上字符,他们的前提有三个,涌现过数字,小写,大写
以上是一般青年解法
那这做弊来的答案,也是很有成就感的,心想这类问题不会有其他答案了吧,但答题者的设想力再次超过了我的设想,以下是其他几种答案,供扩大思绪之用
function validate(password) {
return /^[A-Za-z0-9]{6,}$/.test(password) &&
/[A-Z]+/ .test(password) &&
/[a-z]+/ .test(password) &&
/[0-9]+/ .test(password) ;
}
进行了四个正则考证,用&&相连,避免了正则内部的断言,这是文艺青年解法
下面另有铅笔青年解法,就看看
function validate(password) {
// 1) if the first char is [0-9]:
// a) verify what follows contains at least 1 [a-z]
// b) verify what follows contains at least 1 [A-Z]
// c) verify what follows contains only [0-9a-zA-Z] and at least 5 of them
// 2) if the first char is [a-z]:
// a) verify what follows contains at least 1 [0-9]
// b) verify what follows contains at least 1 [A-Z]
// c) verify what follows contains only [0-9a-zA-Z] and at least 5 of them
// 3) if the first char is [A-Z]:
// a) verify what follows contains at least 1 [a-z]
// b) verify what follows contains at least 1 [0-9]
// c) verify what follows contains only [0-9a-zA-Z] and at least 5 of them
return /^(([0-9](?=[^a-z]*[a-z])(?=[^A-Z]*[A-Z]))([0-9a-zA-z]{5,})|([a-z](?=[^0-9]*[0-9])(?=[^A-Z]*[A-Z]))([0-9a-zA-z]{5,})|([A-Z](?=[^a-z]*[a-z])(?=[^0-9]*[0-9]))([0-9a-zA-z]{5,}))$/.test(password);
}