• <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 天下 閱讀(500) 評論(0)  編輯 收藏 引用

            <2021年3月>
            28123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            導航

            統計

            常用鏈接

            留言簿(4)

            隨筆分類(378)

            隨筆檔案(329)

            鏈接

            最新隨筆

            搜索

            最新評論

            要久久爱在线免费观看| 香蕉久久久久久狠狠色| 久久AV高潮AV无码AV| 久久这里的只有是精品23| 性高湖久久久久久久久AAAAA | 久久天天躁狠狠躁夜夜2020一| 午夜精品久久久久久影视riav | 久久99精品国产99久久| 国产一区二区三区久久精品| 久久亚洲国产成人影院网站| 久久99国内精品自在现线| 久久99精品久久久久久水蜜桃| 伊人久久国产免费观看视频| 久久久久亚洲精品无码蜜桃| 久久国产美女免费观看精品| 久久久国产乱子伦精品作者| 亚洲国产精品无码久久久久久曰 | 久久免费视频1| 99久久无码一区人妻| 伊人久久大香线蕉av一区| 国产激情久久久久影院| 亚洲精品无码久久千人斩| 久久久久久噜噜精品免费直播| 久久99精品久久久久子伦| 亚洲精品99久久久久中文字幕| 精品999久久久久久中文字幕| 99久久精品国产一区二区| 色综合久久久久综合99| 国产成人无码精品久久久久免费| 久久国产色AV免费看| 亚洲精品美女久久777777| 2021国产精品久久精品| 久久久久久国产a免费观看不卡 | 久久天天躁夜夜躁狠狠躁2022 | 久久久久久国产精品无码下载| 亚洲综合精品香蕉久久网97| 国产精品久久久久9999高清| 久久精品亚洲精品国产色婷| 人妻少妇久久中文字幕一区二区 | 久久精品中文字幕一区| 91久久香蕉国产熟女线看|