翼度科技»论坛 编程开发 mysql 查看内容

MySQL实现身份鉴别的项目实践

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
前言

MySQL的身份鉴别是数据库安全的核心命题之一。在每日“拧螺丝”的工作中,我们的开发人员可能会忽略这个问题。正因如此,博主以这个契机,向大家做一次专题介绍。看过此文,相信你能够“上应付得了等保,下对得起公司”。


Q:如何保障MySQL数据库身份鉴别的有效性
  1. 提示:本文示例均已MySQL5.7为例,通过root用户执行相关命令。
复制代码
如何保障MySQL数据库身份鉴别,有很多手段进行识别。博主通过SQL的方式,进行逐一介绍。

一、有效性检查


1. 用户唯一

检查授权的用户是否唯一:
  1. SELECT USER, HOST FROM mysql.user;
复制代码
2. 启用密码验证

检查PLUGIN是否包含
  1. *_password
复制代码
  1. -- mysql_native_password,身份验证插件
  2. SELECT USER, HOST, PLUGIN FROM mysql.user;
复制代码
3. 是否存在空口令用户

检查
  1. authentication_string
复制代码
是否存在空值:
  1. -- authentication_string,加密后密码,即执行password()后的值
  2. SELECT USER, HOST, PLUGIN, authentication_string FROM mysql.user;
复制代码
4. 是否启用口令复杂度校验

检查
  1. validate_password
复制代码
插件,是否已启用:
  1. -- 如果为空,证明未启用该插件
  2. SHOW VARIABLES LIKE 'validate%';
复制代码
5. 是否设置口令的有效期
  1. -- 默认0,永不过期
  2. SHOW VARIABLES LIKE '%default_password_lifetime%';
复制代码
6. 是否限制登录失败尝试次数
  1. -- 如为空,代表未设置,可无限尝试
  2. SHOW VARIABLES LIKE '%connection-control-failed-connections-threshold%';
复制代码
7. 是否设置(超过尝试次数)锁定的最小时长
  1. -- 如为空,代表未设置,永不锁定
  2. SHOW VARIABLES LIKE '%connection-control-min-connection-delay%';
复制代码
8. 是否设置保持登录的有效期
  1. -- 默认0,代表永不退出登录
  2. SHOW VARIABLES LIKE '%wait_timeout%';
复制代码
二、应对方案

针对第一部分的有效性检查中,涉及不满足的配置项,我们可以通过以下措施加以弥补。

1. 空口令问题

如存在空口令,可通过
  1. root
复制代码
执行以下命令:
  1. alter user [USER]@[HOST] identified by '[PASSWORD]';
复制代码
2. 口令复杂度

如未启用口令复杂度,可能会遇到暴力 破 解,因此建议设置相关项。

2.1 安装插件

MySQL默认预留了口令复杂度插件:
  1. validate_password
复制代码
。我们只需要通过root用户安装即可:
  1. INSTALL PLUGIN validate_password SONAME 'validate_password.so';
复制代码
查看是否安装成功(如看到以下记录,代表成功):
  1. SHOW VARIABLES LIKE 'validate%';
复制代码


2.2 参数解释

为加深各位盆友的理解,博主对返回的参数加以说明。
2.2.1 validate_password_policy
MySQL的密码策略包含以下3种:
LOW 或 0代表密码必须满足指定长度。
MEDIUM 或 1(默认)代表密码必须至少包含1个大写字母、1个小写字母、1个数字和1个特殊字符。
STRONG 或 2在满足MEDIUM的基础上,不允许存储在字典文件(dictionary file)中。
2.2.2 配套参数
参数名称用途validate_password_length定义密码长度,默认8位,适用于
  1. LOW 
复制代码
策略。validate_password_mixed_case_count定义大、小写字母的个数,默认1,适用于非
  1. LOW
复制代码
策略。validate_password_number_count定义数字的个数,默认1,适用于非
  1. LOW
复制代码
策略。validate_password_special_char_count定义特殊字符的个数,默认1,适用于非
  1. LOW
复制代码
策略。
2.3 调整参数

掌握了参数特征后,我们可以按需调整相关参数的值,以满足安全需要,执行命令如下:
  1. --必须以root身份执行,且拥有super权限。
  2. set global [具体参数名称]=[VALUE];
复制代码
3. 口令有效期

如满足口令定期更换的安全要求时,必须设置口令的有效期:
  1. -- 必须以root身份执行,设置有效期为90天
  2. set global default_password_lifetime=90;
复制代码
4. 设置登录失败处理

假如要求你限制登录失败的次数以及失败次数达到上限后锁定用户,你该怎么办?先不急,且听博主分解。

4.1 安装插件

满足上述要求,需要安装MySQL自带的插件:
  1. connection_control
复制代码
,命令如下:
  1. -- 必须以root身份执行
  2. INSTALL PLUGIN CONNECTION_CONTROL SONAME 'connection_control.so';
  3. INSTALL PLUGIN CONNECTION_CONTROL_FAILED_LOGIN_ATTEMPTS SONAME 'connection_control.so';
复制代码
4.2 参数解释

参数名称用途connection_control_failed_connections_threshold登录失败尝试次数,默认3,如0代表不限制。connection_control_max_connection_delay登录失败次数满后,再次响应的最大延迟时间(毫秒),建议默认connection_control_min_connection_delay登录失败次数满后,再次响应的最小延迟时间(毫秒)。
4.3 调整参数

掌握了参数特征后,我们同样可以按需调整相关参数的值,执行命令如下:
  1. --必须以root身份执行,且拥有super权限。
  2. set global [具体参数名称]=[VALUE];
复制代码
5. 设置登录保持时间

设置保持登录的有效期,过期自动退出登录状态:
  1. -- 必须以root身份执行,设置保持登录的有效期为1800秒
  2. set global wait_timeout=1800;
复制代码
结语

本文通过案例介绍的方式,针对MySQL不同的安全场景,制定差异化的解决办法。当然完成该过程离不开MySQL自带的插件或访问控制能力。
到此这篇关于MySQL实现身份鉴别的示例代码的文章就介绍到这了,更多相关MySQL 身份鉴别内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

来源:https://www.jb51.net/database/331165f4o.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具