游泳章鱼 发表于 2003-6-10 00:47:00

网通拨号软件Onewave Clinet注册表密码解密算法

首先我们来了解一下网通的拨号软件的密码在注册表中的位置.打开注册表到HKEY_USERS\S-1-5-21-1606980848-920026266-854245398-100\Software\OneWave的项,其中S-1-5-21-1606980848-920026266-854245398-1003为SID(安全表示符,也就是用户名在电脑里的编号,每个电脑,每个用户都是不一样的,你只要打开你自己的)
在……OneWave\NetClient为2.0版本,……\OneWave\NetClient\Setting为1.2版本,如果你保存密码就会在相应的里面创建密码和用户名,如下图
http://hsite.net/51chi/img/bbs/5.gif
1.2版本密码位置

       2.0版本的用户名和密码都经过加密,生成16进制的字符串,如下图。
http://hsite.net/51chi/img/bbs/4.gif
      1.2版本的用户名是明文保存的,密码则经过加密,但是在加密后,有些密文字符是显示不出来的,只有通过修改二进制数据才能看到,然而在win2000和98的注册表中鼠标右键没有“修改二进制数据”,而XP就有,如下图。
http://hsite.net/51chi/img/bbs/6.gif
至于在2000和98下怎么100%翻译密文很麻烦有些密文字符是显示不出来的,不如XP好,XP可以100%翻译。


现在说算法,是我用C语言写的,你可以把它用VB改一下。
1.2版本(需知道密文的二进制数据,也就是在XP下)
printf("Please enter password:");      /*输入一个2位的16进制数据d*/
scanf("%x",&d);
if((d>=0&&d<=32)||(d>=64&&d<=95))      /*计算机将d转换为10进制来计算,如果0<=d<=32或64<=d<=95*/
{b=d%4;                                  /*b=d/4的余数*/
    if(b==0||b==1)                     /*如果b=0或b=1*/
         c=93-d;                         /*c=93-d*/
else if(b==2||b==3)                      /*如果b=2或b=3*/
          c=97-d;                        /*c=97-d*/
}
if((d>=32&&d<=63)||(d>=96&&d<=126))      /*如果0<=d<=32或64<=d<=95*/   
{b=d%4;                                  /*类似以上方法*/
if (b==0||b==1)
c=157-d;
else if (b==2||b==3)
c=161-d;
}
printf("          THE WORD IS:%c\n\n",c);    /*将10进制c对应的ASCⅡ的明文输出*/

      2.0版本很简单只要用每一排16进制的字符串如上图中的例子349F9DA19D以9F-34,9D-34,A1-34,9D-34得到的结果转换为10进制,在对应ASCⅡ就是明文了。


      我用C写了个翻译软件,自己用着,你们用VB写,或加上其他功能的话,别忘了给发我一个,章鱼谢过了^_^

猴子很忙 发表于 2003-6-10 00:53:00

丧心病狂 发表于 2003-6-10 08:49:00

能钻研是强,但楼主能不能在公布程序的时候注意其严整性?

游泳章鱼 发表于 2003-6-10 10:08:00

其实我也只是想说一下算法,至于用什么语言写,发挥的余地很大。表达可能不大好,大家也可以自己研究,我来抛砖。

Gordon 发表于 2003-6-10 13:14:00

不错哦~!~

hater315 发表于 2003-6-10 16:01:00

UP
页: [1]
查看完整版本: 网通拨号软件Onewave Clinet注册表密码解密算法