Passay - LengthComplexityRule
LengthComplexityRule 有助于根据密码长度定义适用的规则。请考虑以下策略。
如果密码长度在 1 到 5 个字符之间,则只允许使用小写字母。
如果密码长度在 6 到 8 个字符之间,则只允许使用 a、b 和 c。
示例
以下示例显示了使用 Passay 库根据上述策略验证密码。
import org.passay.AllowedCharacterRule; import org.passay.CharacterRule; import org.passay.EnglishCharacterData; import org.passay.LengthComplexityRule; import org.passay.PasswordData; import org.passay.PasswordValidator; import org.passay.RuleResult; public class PassayExample { public static void main(String[] args) { LengthComplexityRule lengthComplexityRule = new LengthComplexityRule(); //规则:1 到 5 个字符的密码只能包含小写字母 lengthComplexityRule.addRules("[1,5]", new CharacterRule(EnglishCharacterData.LowerCase, 5)); //8 和 16 个字符 lengthComplexityRule.addRules("[6,8]", new AllowedCharacterRule(new char[] { 'a', 'b', 'c' })); PasswordValidator validator = new PasswordValidator(lengthComplexityRule); PasswordData password = new PasswordData("abcdef"); RuleResult result = validator.validate(password); if(result.isValid()){ System.out.println("Password validated."); }else{ System.out.println("Invalid Password: " + validator.getMessages(result)); } } }
输出
Invalid Password: [ Password contains the illegal character 'd'., Password contains the illegal character 'e'., Password contains the illegal character 'f'., Password meets 0 complexity rules, but 1 are required.]