免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 5808 | 回复: 25
打印 上一主题 下一主题

MySQL密码遗忘解决方法zt [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-05-29 15:28 |只看该作者 |正序浏览
若是windows系统,mysqladmin的密码在my.ini文件中明文存储
Linux中,如果密码遗忘,这里提供几个解决方法
停掉mysql
# /etc/rc.d/init.d/mysql stop

以--skip-grant-table 的參數啟動mysql
# safe_mysql --skip-grant-table&

更改root密码
#mysql
use mysql
UPDATE user SET password=password('new') WHERE user='root';
mysql>; FLUSH PRIVILEGES;
\q

停掉mysql
# mysqladmin -uroot -p shutdown
Enter password:new

第二种可以利用mysql的密码的脆弱加密机制


用skip-grant-table方式启动后查出mysql hash,
#mysql mysql
show tables;
select user,password from user;

之后使用mysqlfast hash 得出密码
老外的源程序
/* This program is public domain. Share and enjoy.
*
* Example:
* $ gcc -O2 -fomit-frame-pointer mysqlfast.c -o mysqlfast
* $ mysqlfast 6294b50f67eda209
* Hash: 6294b50f67eda209
* Trying length 3
* Trying length 4
* Found pass: barf
*
* The MySQL password hash function could be strengthened considerably
* by:
* - making two passes over the password
* - using a bitwise rotate instead of a left shift
* - causing more arithmetic overflows
*/
#include <stdio.h>;
typedef unsigned long u32;
/* Allowable characters in password; 33-126 is printable ascii */
#define MIN_CHAR 33
#define MAX_CHAR 126
/* Maximum length of password */
#define MAX_LEN 12
#define MASK 0x7fffffffL
int crack0(int stop, u32 targ1, u32 targ2, int *pass_ary)
{
  int i, c;
  u32 d, e, sum, step, diff, div, xor1, xor2, state1, state2;
  u32 newstate1, newstate2, newstate3;
  u32 state1_ary[MAX_LEN-2], state2_ary[MAX_LEN-2];
  u32 xor_ary[MAX_LEN-3], step_ary[MAX_LEN-3];
  i = -1;
  sum = 7;
  state1_ary[0] = 1345345333L;
  state2_ary[0] = 0x12345671L;
  while (1) {
    while (i < stop) {
      i++;
      pass_ary = MIN_CHAR;
      step_ary = (state1_ary & 0x3f) + sum;
      xor_ary = step_ary*MIN_CHAR + (state1_ary << ;
      sum += MIN_CHAR;
      state1_ary[i+1] = state1_ary ^ xor_ary;
      state2_ary[i+1] = state2_ary
        + ((state2_ary << ^ state1_ary[i+1]);
    }
    state1 = state1_ary[i+1];
    state2 = state2_ary[i+1];
    step = (state1 & 0x3f) + sum;
    xor1 = step*MIN_CHAR + (state1 << ;
    xor2 = (state2 << ^ state1;
    for (c = MIN_CHAR; c <= MAX_CHAR; c++, xor1 += step) {
      newstate2 = state2 + (xor1 ^ xor2);
      newstate1 = state1 ^ xor1;
      newstate3 = (targ2 - newstate2) ^ (newstate2 << ;
      div = (newstate1 & 0x3f) + sum + c;
      diff = ((newstate3 ^ newstate1) - (newstate1 << ) & MASK;
      if (diff % div != 0) continue;
      d = diff / div;
      if (d < MIN_CHAR || d >; MAX_CHAR) continue;
      div = (newstate3 & 0x3f) + sum + c + d;
      diff = ((targ1 ^ newstate3) - (newstate3 << ) & MASK;
      if (diff % div != 0) continue;
      e = diff / div;
      if (e < MIN_CHAR || e >; MAX_CHAR) continue;
      pass_ary[i+1] = c;
      pass_ary[i+2] = d;
      pass_ary[i+3] = e;
      return 1;
    }
    while (i >;= 0 && pass_ary >;= MAX_CHAR) {
      sum -= MAX_CHAR;
      i--;
    }
    if (i < 0) break;
    pass_ary++;
    xor_ary += step_ary;
    sum++;
    state1_ary[i+1] = state1_ary ^ xor_ary;
    state2_ary[i+1] = state2_ary
      + ((state2_ary << ^ state1_ary[i+1]);
  }
  return 0;
}
void crack(char *hash)
{
  int i, len;
  u32 targ1, targ2, targ3;
  int pass[MAX_LEN];
  if ( sscanf(hash, "%8lx%lx", &targ1, &targ2) != 2 ) {
    printf("Invalid password hash: %s\n", hash);
    return;
  }
  printf("Hash: %08lx%08lx\n", targ1, targ2);
  targ3 = targ2 - targ1;
  targ3 = targ2 - ((targ3 << ^ targ1);
  targ3 = targ2 - ((targ3 << ^ targ1);
  targ3 = targ2 - ((targ3 << 8) ^ targ1);
  for (len = 3; len <= MAX_LEN; len++) {
    printf("Trying length %d\n", len);
    if ( crack0(len-4, targ1, targ3, pass) ) {
      printf("Found pass: ";
      for (i = 0; i < len; i++)
        putchar(pass);
      putchar('\n');
      break;
    }
  }
  if (len >; MAX_LEN)
    printf("ass not found\n";
}
int main(int argc, char *argv[])
{
  int i;
  if (argc <= 1)
    printf("usage: %s hash\n", argv[0]);
  for (i = 1; i < argc; i++)
    crack(argv);
  return 0;
}

论坛徽章:
5
荣誉会员
日期:2011-11-23 16:44:17CU大牛徽章
日期:2013-09-18 15:15:15CU大牛徽章
日期:2013-09-18 15:15:45未羊
日期:2014-02-25 14:37:19射手座
日期:2014-12-26 22:55:37
26 [报告]
发表于 2003-08-12 21:56 |只看该作者

MySQL密码遗忘解决方法zt

是的,要你用safe_mysqld启动mysqld。

论坛徽章:
0
25 [报告]
发表于 2003-08-12 14:06 |只看该作者

MySQL密码遗忘解决方法zt

如题。

论坛徽章:
5
荣誉会员
日期:2011-11-23 16:44:17CU大牛徽章
日期:2013-09-18 15:15:15CU大牛徽章
日期:2013-09-18 15:15:45未羊
日期:2014-02-25 14:37:19射手座
日期:2014-12-26 22:55:37
24 [报告]
发表于 2003-08-11 17:40 |只看该作者

MySQL密码遗忘解决方法zt

多明白啊,告诉你不要用root运行mysqld,用safe_mysqld

论坛徽章:
0
23 [报告]
发表于 2003-08-11 15:02 |只看该作者

MySQL密码遗忘解决方法zt

shell>;mysql -uroot -p
Enter password:
ERROR 1045: Access denied for user: 'root@localhost' (Using password: YES)

shell>; mysqld --skip-grant-tables
Fatal error: Please read "Security" section of the manual to find out how to run mysqld as root!
030811 14:35:17  Aborting

030811 14:35:17  mysqld: Shutdown Complete

shell>; mysql --version
mysql  Ver 12.20 Distrib 4.0.13, for intel-linux (i686)


请问该怎么办阿?

论坛徽章:
0
22 [报告]
发表于 2003-07-25 16:05 |只看该作者

MySQL密码遗忘解决方法zt

不用,立即重建!

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
21 [报告]
发表于 2003-07-25 13:40 |只看该作者

MySQL密码遗忘解决方法zt

把user表删除,重新安装MYSQL行吗?

论坛徽章:
5
荣誉会员
日期:2011-11-23 16:44:17CU大牛徽章
日期:2013-09-18 15:15:15CU大牛徽章
日期:2013-09-18 15:15:45未羊
日期:2014-02-25 14:37:19射手座
日期:2014-12-26 22:55:37
20 [报告]
发表于 2003-07-25 11:10 |只看该作者

MySQL密码遗忘解决方法zt

[quote]原帖由 "HeartIcy"]累,累。说过的话要说第二次,不说了自己看前边说的。我看你是没事找事![/quote 发表:
     
你爱说不说,看前面说的应该是你该看的。人家要怎么恢复给遗忘的秘密,你出了个给个馊主意还耍赖,呵呵。
你可以继续装傻,没有问题,尽管继续。

论坛徽章:
0
19 [报告]
发表于 2003-07-25 11:02 |只看该作者

MySQL密码遗忘解决方法zt

累,累。说过的话要说第二次,不说了自己看前边说的。我看你是没事找事!

论坛徽章:
5
荣誉会员
日期:2011-11-23 16:44:17CU大牛徽章
日期:2013-09-18 15:15:15CU大牛徽章
日期:2013-09-18 15:15:45未羊
日期:2014-02-25 14:37:19射手座
日期:2014-12-26 22:55:37
18 [报告]
发表于 2003-07-25 10:57 |只看该作者

MySQL密码遗忘解决方法zt

[quote]原帖由 "HeartIcy"]哪里哪里 我说得很清楚我是破密码,你非要扯恢复方法。那么就你那恢复策略较高明?屁。。。。 既然密码丢了 忘了还好,要是被人窜权了怎么办?你保证人家就修改你个root?你不做检测就恢复系统?晕倒,天下遇到这种
  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP