• 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
  • 相关阅读:
    1292
    explicit_defaults_for_timestamp
    比较好的平台工具
    git回退到指定版本的代码
    解决catalina.out文件过大的方法
    json字符串转化成对象列表数据
    Java LIST做批量分组切割
    Activiti数据库表结构
    MySQL修改数据库时区
    集合工具类的使用
  • 原文地址:https://www.cnblogs.com/mmdz/p/14737473.html
Copyright © 2020-2023  润新知