我需要使用Java验证密码字符串。这是验证的要求:
在拧了几下并将我的头撞到墙上几次之后,我想出了这个正则表达式
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}$")) {
}
看起来太可怕而且疯了。有没有更好的方法来实现这一使命?
答案 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
但我可以建议您将验证分成相应的类别吗?通过这种方式,它可以更容易,并且您将能够准确地告诉用户他们缺少的是什么。