正则表达式用于验证

时间:2012-12-17 03:09:07

标签: java regex

我需要使用Java验证密码字符串。这是验证的要求:

  • 至少1个号码
  • 至少1个字母字符
  • 至少有1个角色!@#$%^& *()_ + = - 〜`] [{};':“/。>?,<
  • 8到20个字符

在拧了几下并将我的头撞到墙上几次之后,我想出了这个正则表达式

if (!password.matches("^(?=.+[0-9])(?=.+[a-zA-Z])(?=.+[\\x21-\\x2F\\x3A-\\x40\\x5B-\\x60\\x7B-\\x7E])[0-9a-zA-Z\\x21-\\x2F\\x3A-\\x40\\x5B-\\x60\\x7B-\\x7E]{8,20}$")) {

}

看起来太可怕而且疯了。有没有更好的方法来实现这一使命?

3 个答案:

答案 0 :(得分:3)

我建议使用正则表达式来表达他们最擅长的东西,但是使用正则表达式做得不好的代码。像这样的东西。 (对不起,我还没有测试过这段代码,但是即使我犯了错误也不应该运行它。)

Pattern special_chars = Pattern.compile("[!@#$%^&*()_+=-~`\][{};':\"/.>?,<]");
Pattern number_chars = Pattern.compile("[0-9]");
Pattern letter_chars = Pattern.compile("[a-zA-Z]");

boolean valid;

valid = (special_chars.matcher(password).find() &&
        number_chars.matcher(password).find() &&
        letter_chars.matcher(password).find() &&
        8 <= password.length() && password.length() <= 20);

答案 1 :(得分:1)

使用番石榴CharMatcher

// at least 1 number
CharMatcher.inRange('0', '9').countIn(password) >= 1 && 
// at least 1 alphabet character
CharMatcher.inRange('a', 'z').or(inRange('A', 'Z')).countIn(password) >= 1 && 
// at least 1 character from set !@#$%^&*()_+=-~`][{};':"/.>?,<
CharMatcher.anyOf("!@#$%^&*()_+=-~`][{};':\"/.>?,<").countIn(password) >= 1 && 
// 8 to 20 characters
password.length() >= 8 && password.length() <= 20

这假设你想要拉丁字母

答案 2 :(得分:0)

我相信这已经得到了解答。

Regular Expression for password validation

但我可以建议您将验证分成相应的类别吗?通过这种方式,它可以更容易,并且您将能够准确地告诉用户他们缺少的是什么。