快速业务通道

讲解几种破解MySQL数据库root密码的方法

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-03-18


重新连接


mysql>use mysql


mysql>update user set Password=PASSWORD(’xxxxxx’) where User=’root’;


mysql>FLUSH PRIVILEGES;


有一点值得注意:如果你windows 下mysql如果是默认配置的话,注意要还要执行


mysql>delete from user where User=’’;


mysql>delete from user where Host=’%’;


mysql>FLUSH PRIVILEGES;


好了,到这里恢复密码过程就完成了


这个方法么就是有点局限性,你必须也具备另外的user表文件


其他还有几种方法


其它方法一(这个是网上流传较广的方法,mysql中文参考手册上的)


1. 向mysqld server 发送kill命令关掉mysqld server(不是 kill -9),存放进程ID的文件通常在MYSQL的数据库所在的目录中。


killall -TERM mysqld


你必须是UNIX的root用户或者是你所运行的SERVER上的同等用户,才能执行这个操作。


2. 使用`--skip-grant-tables’ 参数来启动 mysqld。 LINUX下:


/usr/bin/safe_mysqld --skip-grant-tables , windows下c:\mysql\bin\mysqld --skip-grant-tables


3. 然后无密码登录到mysqld server ,


>use mysql


>update user set password=password("new_pass") where user="root";


>flush privileges;


你也可以这样做:


mysqladmin -h hostname -u user password ’new password’’


4. 载入权限表:

mysqladmin -h hostname flush-privileges’


或者使用 SQL 命令


FLUSH PRIVILEGES’


5.killall -TERM mysqld


6.用新密码登陆


其它方法二


直接用十六进制编辑器编辑user.MYD文件


不过这个里面我要说明一点,我这里编辑的时候发现个问题,加密的密码串有些是连续存储的,有些的最后两位被切开了,后两位存储在后面其他地方.这一点我还没想明白.还有注意一点就是编辑的是加密过的密码串,也就是说你还是需要另外有user表文件。这种方法和我最上面介绍的方法的区别在于,这种方法直接编辑linux下的user表文件,就不需要重新改文件属主和权限了


修正一下:我在Windows下的实际操作如下


1.关闭正在运行的MySQL。


2.打开DOS窗口,转到mysql\bin目录。


3.输入


mysqld-nt --skip-grant-tables


回车。如果没有出现提示信息,那就对了。


4.再开一个DOS窗口(因为刚才那个DOS窗口已经不能动了),转到mysql\bin目录。


5.输入mysql回车,如果成功,将出现MySQL提示符 >


6. 连接权限数据库


>use mysql;


(>是本来就有的提示符,别忘了最后的分号)


6.改密码:

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号