I have a list of passwords that I need to examine and determine if they meet the default 3 of 4 rule for AD.
Rule is contain 3 of the 4 following requirements: lower case character (a-z) upper case character (A-Z) numeric (0-9) special character ( !@#$%^&*()_+= )
I am still learning Regex. I know how to select only those that meet any one character case, but I am not sure how to do 3 of 4.
As a side note, the AD Complexity has two more subtleties that are important (but out of scope of the original question).
It is really 3 of 5. The fifth is Unicode character. Be nice to update the Regex with that.
The other is you cannot have the sAMAccountName value in whole in the password (case insensitive), nor if you split the displayName value into tokens split upon space, comma, dash, underscore, pound, pipe and something else those tokens (3 chars and longer) cannot be in whole in the password, case insensitive.
You will have to build up the regular expression like this:
I'm not sure if I escaped the special characters correctly. It's kind of dependant on the language/toolkit you're using.
I edited the @saul-dolgin answer to exactly match with the valid charset specified in the question (not a a non-alfanumeric character
[^A-Za-z0-9]
):Microsoft forces passwords to have only characters from their list. I also changed the Maximum lenght to 20.
Does it have to be all one big regex? You could do 4 regexes, each checking one thing and then make sure 3 of the 4 are matches. That would be easier, less error prone and more maintainable.
If you really want one big regex it would be something like this:
Note that it also enforces password length to be between 8 and 255 characters. You can change the "{8,255}" portion in the first section to adjust the length requirements. It is also worth noting that this is working for me in a standard ASP.NET RegularExpressionValidator control.
Matches: "Passw0rd" "passW@rd" "1B2a345@#$%"
Non-Matches: "123123123" "Password" "asdf&"
Source (Matthew Hazzard via RegExLib.com)