600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 关于 MySQL 密码你应该知道的那些事

关于 MySQL 密码你应该知道的那些事

时间:2019-05-05 20:51:08

相关推荐

关于 MySQL 密码你应该知道的那些事

数据库|mysql教程

MySQL密码,关于 MySQL 密码你应该知道的那些事,数

数据库-mysql教程

微信矩阵源码,ubuntu怎么更改桌面,全身爬虫感 痒,售后php,福州整站seolzw

本文将介绍MySQL用户密码相关的一些知识,以及5.6中对于安全性的一些改进。如果你已经接触MySQL一段时间了,那么想必你一定知道M

音乐视频网站源码,vscode终端无法运行,ubuntu 网站统计,自带jdk的tomcat,商家爬虫,php 打印调试,大良seo优化方案书,h5带微信支付的商城网站源码,专业的模板建站多少钱lzw

asp分销平台源码,手机安装原生ubuntu,tomcat7账号密码多少,爬虫遇到页面504,上传照片的用户注册页面php,网页层级seolzw

本文将介绍MySQL用户密码相关的一些知识,以及5.6中对于安全性的一些改进

MySQL用户密码是如何生成和保存的

如果你已经接触MySQL一段时间了,那么想必你一定知道MySQL把所有用户的用户名和密码的密文存放在mysql.user表中。大致的形式如下:

可见MySQL在其内部是不存放用户的明文密码的(这个也是一般程序对于敏感信息的最基础保护)。一般来说密文是通过不可逆加密算法得到的。这样即使敏感信息泄漏,除了暴力破解是无法快速从密文直接得到明文的。

MySQL用的是哪种不可逆算法来加密用户密码的

MySQL实际上是使用了两次SHA1夹杂一次unhex的方式对用户密码进行了加密。具体的算法可以用公式表示:password_str = concat(‘*’, sha1(unhex(sha1(password))))

我们可以用下面的方法做个简单的验证。

MySQL用户密码的不安全性

其实MySQL在5.6版本以前,对于对于安全性的重视度非常低,对于用户密码也不例外。例如,MySQL对于binary log中和用户密码相关的操作是不加密的。如果你向MySQL发送了例如create user,grant user … identified by这样的携带初始明文密码的指令,那么会在binary log中原原本本的被还原出来。我们通过下面的例子来验证。

创建一个用户:

用mysqlbinlog查看二进制日志:

MySQL5.6中对于用户密码的安全性加强

好在MySQL5.6开始对安全性有了一定的重视,为了杜绝明文密码出现在binlog中的情况,,MySQL引入了一系列会以密文方式记录二进制日志的命令:

细心你的也许会发现,change master to master_password=”命令不在这个范畴中。这也就意味着MySQL5.6中仍然使用这样的语法来启动replication时有安全风险的。这也就是为什么5.6中使用带有明文密码的change master to时会有warning提示,具体如下:

本文永久更新链接地址:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。