我想创建一个preg_match
函数来验证我的密码,但我不确定如何编写它以允许使用以下特殊字符:!@#$%
.
if(!preg_match(?????)$/', $password))
这是我想在正则表达式中使用的密码规则:
- 可能包含字母和数字
- 必须包含至少 1 个数字和 1 个字母
- 可能包含以下任何字符:
!@#$%
- 必须是 8-12 个字符
感谢您提供的任何帮助。
我想创建一个preg_match
函数来验证我的密码,但我不确定如何编写它以允许使用以下特殊字符:!@#$%
.
if(!preg_match(?????)$/', $password))
这是我想在正则表达式中使用的密码规则:
!@#$%
感谢您提供的任何帮助。
我认为这应该是这样的:
if(!preg_match('/^(?=.*\d)(?=.*[A-Za-z])[0-9A-Za-z!@#$%]{8,12}$/', $password)) {
echo 'the password does not meet the requirements!';
}
在字符串的开始 ->^
和结束 ->$
之间必须至少有一个数字 ->(?=.*\d)
和至少一个字母 ->(?=.*[A-Za-z])
并且必须是数字、字母或以下之一:!@#$% - >[0-9A-Za-z!@#$%]
并且必须有 8-12 个字符 ->{8,12}
正如 user557846 对您的问题所评论的那样,我还建议您允许更多字符,我通常(如果我使用最大值)至少需要 50 :)
顺便说一句,你可能想看看这个正则表达式教程
preg_match('/^(?=.*\d)(?=.*[@#\-_$%^&+=§!\?])(?=.*[a-z])(?=.*[A-Z])[0-9A-Za-z@#\-_$%^&+=§!\?]{8,20}$/',$password)
我喜欢 r3bel 的回答,所以我玩了一下,最后得到了以下密码检查功能:
function password_strength_check($password, $min_len = 8, $max_len = 70, $req_digit = 1, $req_lower = 1, $req_upper = 1, $req_symbol = 1) {
// Build regex string depending on requirements for the password
$regex = '/^';
if ($req_digit == 1) { $regex .= '(?=.*\d)'; } // Match at least 1 digit
if ($req_lower == 1) { $regex .= '(?=.*[a-z])'; } // Match at least 1 lowercase letter
if ($req_upper == 1) { $regex .= '(?=.*[A-Z])'; } // Match at least 1 uppercase letter
if ($req_symbol == 1) { $regex .= '(?=.*[^a-zA-Z\d])'; } // Match at least 1 character that is none of the above
$regex .= '.{' . $min_len . ',' . $max_len . '}$/';
if(preg_match($regex, $password)) {
return TRUE;
} else {
return FALSE;
}
}
最大/最小长度是默认的或可调整的,每个要求都是默认打开的,但可以关闭,我想支持任何符号,所以最后一个要求是“任何不是上述类型之一的东西”,而不是固定的符号集。
我已经开发了一个完整的正则表达式来进行更复杂的检查
/^(?=.*\d)(?=.*[A-Za-z])(?=.*[A-Z])(?=.*[a-z])(?=.*[ !#$%&'\(\) * +,-.\/[\\] ^ _`{|}~\"])[0-9A-Za-z !#$%&'\(\) * +,-.\/[\\] ^ _`{|}~\"]{8,50}$/
基本上我检查密码是否有 1 个数字、1 个大写字母、1 个小写字母和 1 个特殊字符。我希望这对寻找正则表达式的人有所帮助。
if (!preg_match('/^(?=.*\d)(?=.*[A-Za-z])(?=.*[!@#$%])[0-9A-Za-z!@#$%]
{6,15}$/',($_POST['password']))) {
$message='Password must contain 6 characters of letters, numbers and
at least one special character.';
}
我在这里使用我的drupal 自定义表单完成了此操作hook_form_validate
,密码应该是6 个字母、数字和至少一个特殊字符的字符。
<?
if (!preg_match('/^(?=.*\d)(?=.*[A-Za-z])(?=.*[!@#$%])[0-9A-Za-z!@#$%]{6,15}$/', $form_state['values']['pass'])) {
form_set_error('pass', t('Password must contain 6 characters of letters, numbers and at least one special character.'));
}
?>
让我们看看不同的,我相信用户可以使用密码中所有的ASCII有效字符(32 < ascii_code < 127)
,并创建了一个函数来检查 ASCII 表中的所有字符!
function check($pass, $i = 0){
if(strlen($pass) > $i)
return (0rd(pass[$i]) > 32 and 0rd(pass[$i]) < 127) and check($pass, $i + 1);
}
if(!check($_POST["password"])){
echo "password is wrong";
}
查找字符类,这是正则表达式的一个基本特征。
if(!preg_match('/^(?=.*\d)(?=.*[A-Za-z])[0-9A-Za-z!@#$%]{8,12}$/', $password)) {
echo 'the password does not meet the requirements!';
}
在上面的陈述中..因此存在什么可能的密码?