我正在尝试编写正则表达式以验证令牌。
my token has a following structure
:
digits
small alpha
special characters
upper alpha
(可选?
)可能存在或不存在。注意:可选的[A-Z]字符可能存在于某些令牌中,可能不存在于某些令牌中,当它存在于令牌中时,应在5 or more
次之间。
minimum of 6 to a max of 30
一些有效/无效匹配的示例:
token1 : t4xa@ui13p#o6
breakdown : there are 7 [a-z] , 2 special chracter[@#] , 4 digits [0-9]
VALID MATCH: True
token2: 3@piy13Qx9#13@z1337
breakdown: there are 5 [a-z] , 3 special character [@#] , 10 digits [0-9] and 1 [A-Z](which is optional)
VALID MATCH: False (because `[A-Z]` exist in token but it exist for `1` time, it should exist atleast of 5 or more.)
token3: 3@piy1ABC3Qx9#13@DEGFz1337
breakdown: there are 5[a-z], 7 [A-Z] , 10 digits [0-9]
VALID MATCH: True
^(?=.*[\d])(?=.*[A-Z])(?=.*[a-z])(?=.*[@#])[\w\d@#]{6,30}$
(?=(?:[^A-Z\s]*$|(?:[^A-Z\s]*[A-Z]){5})
您可以使用否定的字符类和量词来检查出现的次数最少。
^(?=(?:[^\d\s]*\d){3})(?=(?:[^a-z\s]*[a-z]){5})(?=(?:[^@#\s]*[@#]){2})(?=(?:[^A-Z\s]*$|(?:[^A-Z\s]*[A-Z]){5}))[\w\d@#]{6,30}$
Regex demo