Passay - 密码验证

典型的密码策略包含一组规则,用于检查密码是否符合组织规则。请考虑以下策略:

  • 密码长度应在 8 到 16 个字符之间。

  • 密码不应包含任何空格。

  • 密码应包含以下各项:大写字母、小写字母、数字和符号。

示例

以下示例显示了使用 Passay 库根据上述策略验证密码。

import java.util.ArrayList;
import java.util.List;

import org.passay.CharacterRule;
import org.passay.EnglishCharacterData;
import org.passay.LengthRule;
import org.passay.PasswordData;
import org.passay.PasswordValidator;
import org.passay.Rule;
import org.passay.RuleResult;
import org.passay.WhitespaceRule;

public class PassayExample {
   public static void main(String[] args) {
        
        List<Rule> rules = new ArrayList<>();
        //规则 1:密码长度应介于
        //8 到 16 个字符之间
        rules.add(new LengthRule(8, 16));
        //规则 2:不允许有空格
        rules.add(new WhitespaceRule());
        //规则 3.a:至少一个大写字符
        rules.add(new CharacterRule(EnglishCharacterData.UpperCase, 1));
        //规则 3.b:至少一个小写字符
        rules.add(new CharacterRule(EnglishCharacterData.LowerCase, 1));
        //规则 3.c:至少一个数字
        rules.add(new CharacterRule(EnglishCharacterData.Digit, 1));
        //规则 3.d:至少一个特殊字符
        rules.add(new CharacterRule(EnglishCharacterData.Special, 1));
        
        PasswordValidator validator = new PasswordValidator(rules);
        PasswordData password = new PasswordData("Microsoft@123");
        RuleResult result = validator.validate(password);
        
        if(result.isValid()){
         System.out.println("Password validated.");
      	} else {
         System.out.println("Invalid Password: " + validator.getMessages(result));            
        }
    }
}

输出

Password validated.