本文整理匯總了PHP中Password::setComplexity方法的典型用法代碼示例。如果您正苦於以下問題:PHP Password::setComplexity方法的具體用法?PHP Password::setComplexity怎麽用?PHP Password::setComplexity使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Password
的用法示例。
在下文中一共展示了Password::setComplexity方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: validatePassword
/**
* Checks for valid password. Returns boolean. The following checks are done:
*
* + min length (constant AUTH_MIN_PASS_LENGTH defined in CAT_Users)
* + max length (constant AUTH_MAX_PASS_LENGTH defined in CAT_Users)
* + is a string (spaces allowed), no control characters
* + if $allow_quotes = false: no quotes
* + if $strict = true: consists of 6 or more letters, digits, underscores
* and hyphens; must contain at least one upper case letter,
* one lower case letter and one digit
*
* Use method getPasswordError() to get an error message on return value false
*
* @access public
* @param string $password
* @param boolean $allow_quotes (default: true)
* @param boolean $strict (default: false)
* @return boolean
*
*/
public static function validatePassword($password, $allow_quotes = true, $strict = false)
{
$min_length = CAT_Registry::exists('AUTH_MIN_PASS_LENGTH') ? CAT_Registry::get('AUTH_MIN_PASS_LENGTH') : 5;
$max_length = CAT_Registry::exists('AUTH_MAX_PASS_LENGTH') ? CAT_Registry::get('AUTH_MAX_PASS_LENGTH') : 20;
// ----- check length -----
if (strlen($password) < $min_length && (!CAT_Registry::exists('ALLOW_SHORT_PASSWORDS') || CAT_Registry::get('ALLOW_SHORT_PASSWORDS') !== true)) {
self::$validatePasswordError = self::lang()->translate('The password is too short.');
return false;
} elseif (strlen($password) > $max_length) {
self::$validatePasswordError = self::lang()->translate('The password is too long.');
return false;
}
// any string that doesn't have control characters (ASCII 0 - 31) - spaces allowed
if (!preg_match('/^[^\\x-\\x1F]+$/D', $password, $match)) {
self::$validatePasswordError = self::lang()->translate('Invalid password!');
return false;
} else {
self::$lastValidatedPassword = $match[0];
}
if (!$allow_quotes) {
// don't allow quotes in the PW!
if (preg_match('/(\\%27)|(\')|(%2D%2D)|(\\-\\-)/i', $password)) {
self::$validatePasswordError = self::lang()->translate('Invalid password!');
return false;
}
}
// check complexity
if ($strict) {
$PASSWORD = new Password();
$PASSWORD->setComplexity($PASSWORD->getComplexityStrict());
if (!$PASSWORD->complexEnough($password, self::get_username())) {
self::$validatePasswordError = self::lang()->translate('The required password complexity is not met') . implode('<br />', $PASSWORD->getPasswordIssues());
return false;
}
}
// all checks done
return true;
}