mysql参数old_password

old-passwords选项的目的是当服务器生成长密码哈希值时,允许维持同4.1之前的客户端的向后兼容。
mysql4.1及以后的版本的账户都采用长密码哈希值,长度为41,4.1版本以前为短密码哈希值,长度为16,这里的old-password指的就是4.1版本以前的短密码哈希值
此选项防止客户端在密码更改操作中在user表中创建长密码哈希值。在这种情况下,该账户不能再用于4.1之前的客户端。
没有old-passwords选项,可能会出现下面的不期望的情况:
a、旧客户端连接有短密码哈希值的账户。
b、客户更改自己的密码。没有old-passwords,可以为该账户生成长密码哈希值。
c、下次旧客户试图连接账户时不能连接上,因为账户有长密码哈希值,需要新的哈希机制进行鉴定。
(一旦账户user表中为长密码哈希值,只有4.1和以后版本的客户端可以鉴定它,因为4.1之前的客户端不理解长哈希)。

开启old-password就是解决mysql 4.1及以后版本对之前版本短密码哈希值的兼容,
mysql> show variables like ‘%password%’;
+—————+——-+
| Variable_name | Value |
+—————+——-+
| old_passwords | OFF | ####这里表明已经关闭了旧密码选项
+—————+——-+
1 row in set (0.00 sec)

##测试一下密码长度mysql> select password(’123456′),length(password(’123456′));
+——————————————-+—————————-+
| password(’123456′) | length(password(’123456′)) |
+——————————————-+—————————-+
| *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | 41 |
+——————————————-+—————————-+
1 row in set (0.00 sec)

很明显,这里是 41位的密码。我们再打开旧密码选项:

mysql> set old_passwords=on; ##这里仅对当前会话测试,若要全局,请在配置中设置或者加入全局声明
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like ‘%password%’;
+—————+——-+
| Variable_name | Value |
+—————+——-+
| old_passwords | ON |
+—————+——-+
1 row in set (0.00 sec)

我们再次来测试pasword函数:
mysql> select password(’123456′),length(password(’123456′));
+——————–+—————————-+
| password(’123456′) | length(password(’123456′)) |
+——————–+—————————-+
| 565491d704013245 | 16 |
+——————–+—————————-+
1 row in set (0.00 sec)

发表评论

您的电子邮箱地址不会被公开。 必填项已用*标注