MySQL的native_password
认证插件是MySQL 5.5及更高版本中默认使用的身份验证插件
- 客户端发送连接请求到服务器,包含用户名和其他相关信息。
- 服务器生成一个随机字节串(挑战)并将其发送给客户端。
- 客户端使用以下算法计算哈希值:
a. 对用户密码进行哈希处理,得到
hash_stage1
。 b. 对hash_stage1
再次进行哈希处理,得到hash_stage2
。 c. 将hash_stage2
与挑战字节串进行异或操作,得到最终的哈希值。 - 客户端将计算出的哈希值发送回服务器。
- 服务器使用相同的算法计算用户密码的哈希值,并与客户端发送的哈希值进行比较。如果两者相等,则身份验证成功;否则,身份验证失败。
需要注意的是,native_password
认证插件存在安全风险,因为它使用了较弱的加密算法。为了提高安全性,建议使用更强大的认证插件,如caching_sha2_password
。要切换到caching_sha2_password
认证插件,可以在MySQL配置文件中设置default_authentication_plugin=caching_sha2_password
,然后重启MySQL服务。