mysql错误 "Your password does not satisfy the current policy requirements"

这是 mysql 初始化时,使用临时密码,修改自定义密码时,由于自定义密码比较简单,就出现了不符合密码策略的问题。

如下图:

 

问题原因:

设置密码的验证强度等级达不到标准

 

解决办法:

1、查看 mysql 初始的密码策略,
输入语句 “ SHOW VARIABLES LIKE 'validate_password%';  ” 进行查看,
如下图:

关于 mysql 密码策略相关参数

1)、validate_password_length  固定密码的总长度;
2)、validate_password_dictionary_file 指定密码验证的文件路径;
3)、validate_password_mixed_case_count  整个密码中至少要包含大/小写字母的总个数;
4)、validate_password_number_count  整个密码中至少要包含阿拉伯数字的个数;
5)、validate_password_policy 指定密码的强度验证等级,默认为 MEDIUM;
        关于 validate_password_policy 的取值:
        0/LOW:只验证长度;
        1/MEDIUM:验证长度、数字、大小写、特殊字符;
        2/STRONG:验证长度、数字、大小写、特殊字符、字典文件;
6)、validate_password_special_char_count 整个密码中至少要包含特殊字符的个数;

 

2、首先需要设置密码的验证强度等级,设置 validate_password_policy 的全局参数为 LOW 即可

set global validate_password_policy=LOW;

 

3、当前密码长度为 8 ,如果不介意的话就不用修改了,按照通用的来讲,设置为 6 位的密码,设置 validate_password_length 的全局参数为 6 即可

set global validate_password_length=6;
// 注:在默认密码的长度最小值为 4 ,由 大/小写字母各一个 + 阿拉伯数字一个 + 特殊字符一个,只要设置密码的长度小于 3 ,都将自动设值为 4

 

以下操作:

mysql> set global validate_password_policy=0;    //设置密码验证(只验证长度)
Query OK, 0 rows affected (0.00 sec)

mysql> set global validate_password_length=1;    //设置密码长度
Query OK, 0 rows affected (0.00 sec)

mysql> ALTER USER USER() IDENTIFIED BY 'root';   //设置密码
Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges ;    //刷新生效
Query OK, 0 rows affected (0.00 sec)

mysql> quit

 

posted @ 2021-05-07 00:06  梅子猪  阅读(1336)  评论(0编辑  收藏  举报