• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            天下

            記錄修行的印記

            單文件版MD5函數

            //MD5.cpp
            #include <string>
            std::
            string MD5(std::string s)
            {
                
            const char HEX_CHAR[]={'0''1''2''3''4''5''6''7',
                    
            '8''9''a''b''c''d''e''f'};

                
            const unsigned long Md5Calc_t[ 64 ] = {
                    
            0xd76aa4780xe8c7b7560x242070db0xc1bdceee,
                    
            0xf57c0faf0x4787c62a0xa83046130xfd469501,
                    
            0x698098d80x8b44f7af0xffff5bb10x895cd7be,
                    
            0x6b9011220xfd9871930xa679438e0x49b40821,

                    
            0xf61e25620xc040b3400x265e5a510xe9b6c7aa,
                    
            0xd62f105d0x024414530xd8a1e6810xe7d3fbc8,
                    
            0x21e1cde60xc33707d60xf4d50d870x455a14ed,
                    
            0xa9e3e9050xfcefa3f80x676f02d90x8d2a4c8a,

                    
            0xfffa39420x8771f6810x6d9d61220xfde5380c,
                    
            0xa4beea440x4bdecfa90xf6bb4b600xbebfbc70,
                    
            0x289b7ec60xeaa127fa0xd4ef30850x04881d05,
                    
            0xd9d4d0390xe6db99e50x1fa27cf80xc4ac5665,

                    
            0xf42922440x432aff970xab9423a70xfc93a039,
                    
            0x655b59c30x8f0ccc920xffeff47d0x85845dd1,
                    
            0x6fa87e4f0xfe2ce6e00xa30143140x4e0811a1,
                    
            0xf7537e820xbd3af2350x2ad7d2bb0xeb86d391
                };

                
            const unsigned long Md5Calc_s[ 16 ] = { 7,12,17,22,59,14,204,11,16,23,6,10,15,21 };

                
            //擴展成K*512位
                unsigned long *data;
                
            int l;
                l 
            = s.length()*8;
                data 
            = new unsigned long[((l/512)+1)*512];
                memset(data, 
            0sizeof(data[0])*((l/512)+1)*512);
                
            for(unsigned int i = 0; i < s.length(); ++i){
                    data[i 
            / 4|= s[i] << 8*((i % 4));
                }
                data[s.length() 
            / 4|= 0x80 << 8*((s.length()%4));
                data[((l
            /512)+1)*512/32-2]=l;
                l 
            = (l/512)+1;
                
            //開始計算
                unsigned long H[4], a, b, c, d;
                H[
            0]=0x67452301, H[1]=0xefcdab89, H[2]=0x98badcfe, H[3]=0x10325476;

                
            for(int i = 0; i<l; ++i){
                    unsigned 
            long M[16];
                    
            for(int t = 0; t<16++t)
                        M[t] 
            = data[i*16+t];

                    a 
            = H[0], b = H[1], c = H[2], d = H[3];

                    unsigned 
            long s, k, x, e;
                    s 
            = k = 0;
                    
            /** Turn 1, F */
                    s 
            = k = 0;
                    
            for( x = 0; x < 16; x ++ ){
                        e 
            = ( b & c ) | ( ~& d );
                        e 
            = a + e + M[ k ] + Md5Calc_t[ x ];
                        e 
            = ( e >> ( 32 - Md5Calc_s[ s ] )) | ( e << Md5Calc_s[ s ] );
                        a 
            = b + e;
                        e 
            = d; d = c; c = b; b = a; a = e;
                        s 
            = ( s + 1 ) % 4; k ++;
                    }

                    
            /** Turn 2, G */
                    k 
            = 1; s = 4;
                    
            for( x = 16; x < 32; x ++ ){
                        e 
            = ( b & d ) | ( c & ~d );
                        e 
            = a + e + M[ k ] + Md5Calc_t[ x ];
                        e 
            = ( e >> ( 32 - Md5Calc_s[ s ] )) | ( e << Md5Calc_s[ s ] );
                        a 
            = b + e;
                        e 
            = d; d = c; c = b; b = a; a = e;
                        k 
            = ( k + 5 ) % 16;
                        s 
            = ( s - 3 ) % 4 + 4;
                    }

                    
            /** Turn 3, H */
                    k 
            = 5; s = 8;
                    
            for( x = 32; x < 48; x ++ ){
                        e 
            = b ^ c ^ d;
                        e 
            = a + e + M[ k ] + Md5Calc_t[ x ];
                        e 
            = ( e >> ( 32 - Md5Calc_s[ s ] )) | ( e << Md5Calc_s[ s ] );
                        a 
            = b + e;
                        e 
            = d; d = c; c = b; b = a; a = e;
                        k 
            = ( k + 3 ) % 16;
                        s 
            = ( s - 7 ) % 4 + 8;
                    }

                    
            /** Turn 4, I */
                    k 
            = 0; s = 12;
                    
            for( x = 48; x < 64; x ++ ){
                        e 
            = c ^ ( b | ~d );
                        e 
            = a + e + M[ k ] + Md5Calc_t[ x ];
                        e 
            = ( e >> ( 32 - Md5Calc_s[ s ] )) | ( e << Md5Calc_s[ s ] );
                        a 
            = b + e;
                        e 
            = d; d = c; c = b; b = a; a = e;
                        k 
            = ( k + 7 ) % 16;
                        s 
            = ( s - 11 ) % 4  + 12;
                    }

                    H[
            0+= a;
                    H[
            1+= b;
                    H[
            2+= c;
                    H[
            3+= d;
                }
                
            char buf[33];
                
            for(int i = 0; i<32++i){
                    buf[i] 
            = HEX_CHAR[(H[i / 8>> (4*((i % 8))))&0xf];
                }
                
            for(int i = 0; i<32; i += 2){
                    
            char tmp = buf[i];
                    buf[i] 
            = buf[i+1];
                    buf[i
            +1= tmp;
                }
                buf[
            32= '\0';
                
            return std::string(buf);
            }

            //Test
            //#include <iostream>
            //using namespace std;
            //int main(int argc, char* argv[])
            //{
            //    char s[100];
            //    std::string md5;
            //    while(true){
            //        scanf("%s", s);
            //        md5 = MD5(s);
            //        cout << md5 << endl;
            //    }
            //    return 0;
            //}

            posted on 2012-01-12 16:56 天下 閱讀(494) 評論(0)  編輯 收藏 引用

            <2012年1月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            久久只有这精品99| 欧美大战日韩91综合一区婷婷久久青草| 免费无码国产欧美久久18| 久久精品日日躁夜夜躁欧美| 99国产欧美久久久精品蜜芽| 无码任你躁久久久久久久| 色综合久久无码五十路人妻| 国产69精品久久久久99| 免费精品久久天干天干| 国产日韩久久免费影院 | 久久精品午夜一区二区福利| 麻豆精品久久精品色综合| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 大香网伊人久久综合网2020| 亚洲人成无码www久久久| 国产成人久久精品区一区二区| 亚洲国产高清精品线久久 | 97r久久精品国产99国产精| 亚洲精品tv久久久久久久久久| 99久久er这里只有精品18| 日本精品久久久久影院日本 | 久久综合给合久久狠狠狠97色| 久久久久国产成人精品亚洲午夜| 91精品国产色综合久久| 久久久久人妻一区二区三区| 久久九九免费高清视频| 伊人热人久久中文字幕| 99久久国产热无码精品免费| 97精品依人久久久大香线蕉97| 奇米影视7777久久精品人人爽| 亚洲国产婷婷香蕉久久久久久| 久久夜色精品国产亚洲av| 久久精品视屏| 色播久久人人爽人人爽人人片aV| 国产成人精品久久综合| 国产A级毛片久久久精品毛片| 国产精品久久久久久| 久久夜色tv网站| 97精品国产97久久久久久免费| 国产成人精品综合久久久| 一级做a爱片久久毛片|