阅读内容 

如何设置MYSQL的口令

[日期:2006-02-23] 来源:不详  作者:佚名 [字体: ]
当你使用INSERTUPDATE语句存储一个非空的口令时,你必须使用PASSword()函数加密它。这是因为在user表中以加密形式存储口令,而不是作为纯文本。如果你忘记这个事实,你可能像这样试图设置口令:

shell> MySQL -u root mysql

MySQL> INSERT INTO user (Host,User,Password) VALUES('%','jeffrey','biscuit');

MySQL> FLUSH PRIVILEGES

结果是纯文本值'biscuit'作为口令被存储在user表中。在用户jeffrey试图用这个口令连接服务器时,MySQL客户用PASSword()加密它并且将结果送给服务器,服务器比较在user表中的值(它是纯文本值'biscuit')和加密的口令(而不是 'biscuit'),比较失败并且服务器拒绝连接:

shell> MySQL -u jeffrey -pbiscuit test

Access denied

因为当他们被插入user表时,口令必须被加密,相反,INSERT语句应该象这样被指定:

MySQL> INSERT INTO user (Host,User,Password)

VALUES('%','jeffrey',PASSword('biscuit'));

当你使用SET PASSword语句时,你也必须使用PASSWORD()函数:

MySQL> SET PASSword FOR jeffrey@"%" = PASSWORD('biscuit');

如果你使用GRANT ... IDENTIFIED BY语句或MySQLadmin password命令设置口令,PASSWORD()函数是不必要的。他们都考虑到为你加密口令,多以你可像这样指定一个口令'biscuit'

MySQL> GRANT USAGE ON *.* TO jeffrey@"%" IDENTIFIED BY 'biscuit';

或 shell> MySQLadmin -u jeffrey password biscuit

注意: PASSword()不不同于Unix口令加密方法。

阅读:
录入:

推荐 】 【 打印
相关新闻      
本文评论       全部评论
发表评论
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款


点评: 字数
姓名:
Advertisement
内容查询


Advertisement